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Предисловие 


Одной из главных задач корпоративных информационных систем, далее — 
ИС, является оперативное представление информации, необходимой для 
принятия решений. Вместе с тем структура современных СУБД, на которых 
основаны ИС, ориентирована в первую очередь на компактное и непроти¬ 
воречивое хранение информации, а не на оптимизацию выборки данных. 
Вследствие этого информация, хранящаяся в корпоративных информацион¬ 
ных системах, не всегда используется эффективно. Основной проблемой 
становится не хранение информации, а представление ее конечному поль¬ 
зователю в виде отчета. Традиционно ИС масштаба предприятия имеют 
ограниченное число встроенных отчетов, прямое назначение которых — 
представление отчетной информации вышестоящим организациям или госу¬ 
дарственным службам, а не информационная поддержка руководящего зве¬ 
на. Специфика аналитических отчетов, предназначенных для облегчения 
процесса принятия решений, состоит в их изменчивости, поскольку в ре¬ 
альной жизни требования бизнеса меняются чуть ли не каждый день. Зака¬ 
зы на разработку таких отчетов поступают разработчикам отдела автомати¬ 
зации предприятия, если таковой имеется, либо разработчикам сторонних 
фирм, причем потребности в аналитических отчетах растут по мере их соз¬ 
дания в геометрической прогрессии. Рано или поздно разработчик понима¬ 
ет, что решить проблему средствами среды разработки ИС крайне затрудни¬ 
тельно. Для этого гораздо лучше подходит специализированный генератор 
отчетов, подобный Сгузіаі КероЛз. 

Существуют различные подходы к внедрению С гузіаі КероЛз как инструмен¬ 
та создания отчета в компании. Наиболее очевидный и, на первый взгляд, 
простой подход — обучение служащих компании самостоятельному исполь¬ 
зованию Сгузіаі КероЛз для создания отчетов. К сожалению, такой путь тя¬ 
жело реализовать на практике. Дело не в сложности освоения Сгузіаі 
КероЛз — навыкам работы в инструментальной среде Сгузіаі КероЛз можно 
быстро научить даже слабо подготовленного пользователя. Проблема заклю¬ 
чается в источнике данных, с которыми будет работать Сгузіаі КероЛз. 
Пользователь в этом случае обращается непосредственно к базе данных 
и должен понимать, что такое структура данных, и разбираться в соответствии 
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названий таблиц и полей бизнес-логике. Подаатяющее большинство ИС для 
промышленности и бизнеса имеют в качестве источников данных СУБД 
западных фирм, для которых локализация далеко не первоочередная задача, 
поэтому русификация технологической внутренней информации ИС — до¬ 
полнительная "головная боль" отечественных разработчиков. Следовательно, 
пользователь Сгузіаі Керогіз может увидеть только англоязычные 
"технические" наименования объектов баз данных, что затрудняет работу. 
Поэтому чаще более эффективным оказывается другой подход — иметь на 
предприятии специалиста, профессионально занимающегося генерацией 
отчетов. Такой специалист не обязательно должен быть программистом, но 
ему необходимо знать предметную область, структуру данных, особенно 
с точки зрения ее соответствия предметной области, и развитые возможно¬ 
сти генератора отчетов. Сгузіаі Керогіз имеет мощный инструментарий, 
предназначенный для таких специалистов, позволяющий, например, выпол¬ 
нять сложную статистическую обработку или объединять данные из разно¬ 
родных источников, например, ОВР-файлов и реляционных СУБД. 

Третий подход — встраивание отчетов Сгузіаі Керогіз в клиентские части 
ИС, созданные при помощи других средств разработки, таких как ѴВ, Ро\ѵег 
ВиіЫег, Оеірііі, либо публикация отчетов на тонком клиенте с использова¬ 
нием технологии Іпігапеі. В результате пользователь может вызывать и про¬ 
сматривать отчеты в привычной для себя среде. При этом задача создания 
отчета не снимается, облегчается лишь проблема распространения отчета, 
поэтому такой подход может служить дополнением, а не альтернативой пре¬ 
дыдущим. 

Сгузіаі КероПз версии 9 предлагается фирмой-производителем Сгузіаі 
Оесізіопз в четырех вариантах поставки: Зіапсіагсі, РгоГеззіопаІ, Оеѵеіорег и 
Абѵапсесі. Каждый из вариантов Сгузіаі Керогіз предназначен для опреде¬ 
ленного круга пользователей. Наиболее дешевый вариант — Зіапсіагсі пред¬ 
ставляет собой эффективный инструмент создания отчетов для начинаю¬ 
щих, поскольку средства мастера отчетов позволяют работать с Сгузіаі 
Керогіз пользователям, не имеющим навыков программирования, и для 
профессионалов, которым адресован мощный язык программирования. Ва¬ 
риант Зіапсіагсі содержит средства доступа к "настольным" базам данных, но 
имеет ограниченный набор драйверов доступа к корпоративным СУБД. 

Вариант Ргоіеззіопаі по сравнению с Зіапсіагсі дополнен средствами доступа 
к данным практически из любого источника, включая ХМЬ, ОІАР, реляци¬ 
онные базы данных и т. д. Кроме того, вариант Ргоіеззіопаі включает храни¬ 
лище для повторно используемых компонентов и расширенный набор 
средств для просмотра отчетов, в том числе ШЕВ-интерфейс. 

В вариант Оеѵеіорег дополнительно входят средства, позволяющие интегри¬ 
ровать отчеты в приложения, созданные в распространенных средах разра¬ 
ботки. В состав Оеѵеіорег входит АРІ для создания, просмотра и изменения 
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отчетов, а также набор инструментальных средств (.іаѵа, .ЫЕТ и СОМ) для 
просмотра отчетов. 

Асіѵапсесі представляет собой наиболее дорогой и полный вариант поставки 
Сгузіаі КероП$. По сравнению с вариантом Оеѵеіорег в него включены набо¬ 
ры инструментальных средств (.Іаѵа, Л ! ЕТ и СОМ) для создания и измене¬ 
ния отчетов, инструменты доступа к определяемым пользователем источни¬ 
кам данных — ЛЧЕТ, .ІаѵаВеапз и СОМ, а также отсутствуют лицензионные 
ограничения на развертывание отчетов. 

В этой книге будут показаны основные возможности среды С гузіаі Керогіз 
релиз 9 применительно к наиболее полному варианту поставки Асіѵапсесі и 
практические приемы создания отчетов. 

Книга состоит из девяти глав и двух приложений. 

Первая глава посвящена обзору инструментальной среды Сгузіаі Яерогіз. 

Во второй главе рассматриваются приемы создания стандартных отчетов, 
как с помощью мастера отчетов, так и с использованием инструментальных 
средств. 

В третьей главе излагаются принципы создания более сложных отчетов, 
включающих выборку, сортировку и сложную группировку данных. 

Четвертая глава посвящена включению в отчет диаграмм и географических 
карт. 

В пятой главе рассматривается создание и использование формул Сгузіаі 
Керогіз. 

В шестой главе описываются приемы сложного форматирования объектов 
отчетов, в том числе с использованием формул Сгузіаі Керогіз, и специаль¬ 
ные отчеты, как-то: матричные отчеты, отчеты, содержащие подотчеты 
и отчеты на основе ОЕАР-источников данных. 

Седьмая глава посвящена обзору способов связи Сгузіаі КероПз с источни¬ 
ками данных. Особое внимание уделяется работе с 8фЬ-серверами. Дается 
краткий обзор языка и особенностей его применения в среде Сгузіаі 
Керогіз. 

В восьмой главе рассматриваются различные методы распространения отче¬ 
тов Сгузіаі Керогіз — от экспорта в распространенные форматы до распро¬ 
странения с помощью специализированного продукта — Сгузіаі КероПз 
Епіегргізе. 

Девятая глава представляет особый интерес для профессиональных разра¬ 
ботчиков информационных систем. В ней рассматривается использование 
Сгузіаі КероП Ргіпі Еп§іпе АРІ (Арріісаііоп Рго§гаш ІпІегГасе, интерфейс 
прикладных программ) и встраиваемых компонентов Сгузіаі Керогіз (Оеірйі 
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Предисловие 


и Ѵізиаі Вазіс), их использование для интеграции отчетов в информацион¬ 
ные системы, созданных в различных средах разработки. 

Приложение 1 представляет собой перечень и подробное описание функций 
Сгуктаі Нерол Ргіпі Еп§іпе АРІ (СНРЕ). 

В приложении 2 приводится описание переменных, используемых при работе 
с функциями Сгузіаі Нерон Ргіпі Еп§іпе АРІ и имеющих тип запись или 
структура. 

В некоторых главах читателю предлагается сделать упражнения. Во всех 
примерах и упражнениях, если это не оговорено особо, в качестве источни¬ 
ка данных используется файл хігеше.тбЬ, который после инсталляции 
Сгузіаі Нерогіз можно найти в каталоге Рго§гат Рііез/Сгузіаі Оесізіопз/ 
Сгузіаі Неропз 9/5атр1ез/Еп/ОаіаЬазез. 




Глава 1 



Инструментальная среда 
Сгузіаі Верогіз 9 


1.1. Панели инструментов 
Сгузіаі Верогіз 9 


Сгузіаі Керогіз 9 имеет мощную и интуитивно понятную среду разработки 
отчетов. На рис. 1.1 показано главное окно Сгузіаі Керогіз 9. 



і ос? - м і @ й'ЪЬн'*і'“ х "біі’ *т 
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Рис. 1 . 1 . Главное окно Сгузіаі Верогіз 


Системное меню Сопігоі Мепи Вох находится в левом верхнем углу, кнопки 
Махітіге и Міпітіге — в правом верхнем. В верхней части окна, сразу под 
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заголовком, находится главное меню Сгузіаі Керогк 9 (Мегш Ьаг). В нижней 
части окна находится строка состояния §(аіи$ Ваг. 

В средней части главного окна находится окно просмотра и редактирования 
отчета с двумя вкладками — Бе8І§п и Ргеѵіеѵ. Режим разработки отчета 
Бе8І§п предназначен для создания и редактирования отчета, режим про¬ 
смотра Ргеѵіе\ѵ — для его просмотра. Сгузіаі Керогй 9 позволяет создавать 
новые объекты и изменять их расположение, размеры и другие свойства как 
в режиме Пе$і§п, так и в режиме Ргеѵіеч'. Подробнее о создании и измене¬ 
нии отчетов в режимах Ое$і§п и Ргеѵіе\ѵ будет рассказано в последующих 
главах. 

Наиболее часто встречающиеся действия вынесены в панели инструментов, 
которые размещены в верхней части окна. Всего Сгузіаі Керогіз 9 имеет че¬ 
тыре панели инструментов: главную 8іашІаг<і, форматирования РогтаІІіп§, 
панель инструментов для вставки объектов в отчет Іпзегі Тооіз и панель ин¬ 
струментов для настройки отчетов Ехрегі Тооіз. 

Функциональность главной панели инструментов доступна также из основ¬ 
ного меню Сгузіаі Керогіз 9 (табл. 1.1). 


Элемент 

управления 


№ 


Ш; 


13 


а 


ш 






Ча, 




Таблица 1.1. Элементы управления главной панели 
инструментов Сгузіаі Пероііз 


Описание 

Соответствующая команда 
меню 

Создать новый отчет 

Рііе | Ыеѵі/... 

Открыть отчет 

Рііе | Ореп... 

Сохранить отчет 

Рііе | Заѵе... 

Напечатать отчет 

Рііе | Ргіпі | Ргіпіег... 

Просмотреть отчет 

Рііе | Ргіпі Ргеѵіеѵѵ... 

Экспорт отчета 

Рііе | Ехрог-1... 

Обновление отчета 

Верогі | ВеігезЬ Верогі Раіа 

Вырезать (объект) 

Есііі | Сиі 

Копировать (объект) 

Есііі | Сору 

Вставить (объект) 

Есііі I Разіе 
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Таблица 1.1 (окончание) 


Элемент 

управления 








ц 


|іоо* 




Описание 


Отмена действия. Может быть 
отменено несколько предыду¬ 
щих действий 

Повтор действия. Может быть 
повторено несколько предыду¬ 
щих действий 

Включение и выключение окна■ 
Огоир Тгее в режиме просмотра 
отчета 

Включение и выключение окна 
Ріеісі Ехріогег 

Включение и выключение окна 
Перогі Ехріогег 

Включение и выключение окна 
Яерозііогу Ехріогег 

Поиск в отчете 
Изменение масштаба отчета 
Вызов контекстной справки 


Соответствующая команда 
меню 

Есііі | Ііпсіо 

Есііі I Яесіо 

Ѵіеѵѵ | Сгоир Тгее 

Ѵіеѵѵ | Ріеісі Ехріогег 
Ѵіеш | Яерогі Ехріогег 
Ѵіеи/ 1 Яерозііогу Ехріогег 

Есііі | Ріпсі... 

Ѵіеѵг | 2оот... 

Неір | Сопіехі Иеір 


Каждую панель можно показать или скрыть с помощью редактора ТооІЬагя, 
который вызывается командой Ѵіеіѵ | ТооІЬагв главного меню (рис. 1.2). 


Т ооІЬаіз ЕЗ 

К 


111111Щ 

Иі 



р 

1 


в 


г.. ѵ Л; /•.Л-.'! 

—и 
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Ш 
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1 

;И|! 

рш§1 

р 



ІЙ 


ІЁІІІШІІІІё 

III 

Я ВЦ| 


I 





Г іэідеВійот $ Р ЕЬоѵчТооІТцк , * 


Рис. 1.2. Диалоговое окно ТооІЬагз 
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Любая панель инструментов может быть перемещена в окне программы ме¬ 
тодом Ога§&Огор ("перетащить и отпустить"). 

Панель форматирования содержит инструменты форматирования объектов 
отчета и становится доступной только в том случае, когда фокус установлен 
на соответствующем объекте. Элементы управления панели форматирования 
приведены в таблице 1.2. 

Таблица 1.2. Элементы управления панели форматирования Сгузіа! Яерогіз 9 


Элемент Описание 

управления 



Выбор шрифта для выделенного объекта отчета 


Выбор размера шрифта для выделенного объекта отчета 
Увеличение и уменьшение шрифта 

Установка полужирного шрифта, курсива и подчеркнуто¬ 
го шрифта 

Форматирование текста объекта по левому краю, цен¬ 
тру, правому краю и выравнивание текста соответствен¬ 
но 

Выбор цвета шрифта объекта 
Установка рамок 
Скрытие объекта 

Запрет/разрешение форматирования объекта 

Запрет/разрешение изменения размера и положения 
объекта 

Включение/выключение отображения символа валюты 
для полей типа Сиггепсу 

Включение/выключение отображения символа раздели¬ 
теля тысяч для полей типа Сиггепсу и ЫигпЬег 

Включение/выключение отображения символа процента 
для полей типа А ІитЬег 

Уменьшение и увеличение отображаемого количества 
знаков после запятой для полей типа Сиггепсу и ЫитЬег 
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Для вставки в отчет новых объектов, например текстовых объектов, 
групп или суммирующих полей служит специальная панель вставки 
(табл. 1.3). 


Таблица 1.3. Элементы управления панели инструментов 

для вставки объектов в отчет 


Элемент Описание Соответствующая команда 

управления меню 


уЩ 

Вставить текстовый объект 

Іпзегі | 

Техі ОЬіесі 

щ 

Вставить группу 

Іпзегі | 

Сгоир... 

Щ 

Вставить суммирующее поле 

Іпзегі | 

Зиттагу... 

р 

Вставить объект Сгозз-ТаЬ 
(матричный отчет) 

Іпзегі | 

Сгозз-ТаЬ... 

Ш 

Вставить объект 01.АР Ѳгіб 
(матричный отчет на основе 
ОІ_АР-источника данных) 

Іпзегі | 

ОІ.АР СгісІ... 

Щи 

Вставить подотчет 

Іпзегі | 

ЗиЬгерогі... 

ш 

Нарисовать линию 

Іпзегі | 

І-Іпе 

К! 

Нарисовать прямоугольник 

Іпзегі | 

Вох 

И 

Вставить изображение 

Іпзегі | 

Рісіцге... 

ш 

Вставить диаграмму 

Іпзегі | 

СЬагі... 

1 

Вставить географическую карту 

Іпзегі | 

Мар... 


Панель инструментов для настройки отчетов (табл. 1.4) позволяет вызвать 
диалоговые окна, с помощью которых можно установить сортировку данных 
отчета, произвести выборку и группировку данных, связать таблицы базы 
данных и изменить свойства любого объекта отчета. Подробнее работа 
с такими диалоговыми окнами будет рассмотрена в последующих главах 
книги. 
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Таблица 1.4. Элементы управления панели инструментов для анализа 

Элемент Описание 

управления 

Соответствующая команда 
меню 

|Щ 

Вызов диалогового окна ОаіаЬазе 
Ехрегі, с помощью которого можно 
связать данные из таблиц баз дан¬ 
ных 

йаіаЬазе | ОаіаЬазе Ехрегі... 

ж 

Вызов диалогового окна Сгоир 
Ехрегі для изменения порядка 
группировки и свойств групп 

Верогі | 

Сгоир Ехрегі... 

ш 

Вызов диалогового окна Сгоир Зогі 
Ехрегі для специального порядка 
группировки, например, группиров¬ 
ки Тор N 

Верогі | 

Сгоир Зогі Ехрегі... 

и 

Вызов диалогового окна Весогсі 
Зогі Ехрегі для сортировки строк 
отчета 

Верогі | 

Весогсі Зогі Ехрегі... 

& 

Вызов диалогового окна Зеіесі 

I Ехрегі для создания и изменения 

правил выборки данных 

Верогі | 

Зеіесі Ехрегі... 

ш 

Вызов диалогового окна Зесііоп 
Ехрегі для форматирования секций 
отчета 

Верогі | 

Зесііоп Ехрегі... 


Вызов диалогового окна Рогтиіа 

1 ѴѴогкзНор для доступа к хранилищу 

формул 

Верогі | 

Рогтиіа ѴѴогкзНор... 

ей 

Вызов диалогового окна ОІ.АР 

Верогі | 

ОІ.АР Верогі 


Верогі Сгеаііоп ѴУігагсІ 

Зеіііпд. 


.Щ- 

Вызов диалогового окна — редакто¬ 
ра шаблонов отчетов Тетріаіе 
Ехрегі 

Верогі | 

Тетріаіе Ехрегі... 

щ 

Вызов диалогового окна — редакто¬ 
ра свойств объектов отчета Рогтаі 
Есіііог 

Рогтаі | 

Рогтаі Есіііог... 

% 

Создание гиперссылки для объекта 
отчета 

Рогтаі | 

Нурегііпк... 


Вызов диалогового окна НідЫідНііпд 
Ехрегі для выделения объекта отче¬ 
та по условию, например, цветом 

Рогтаі | 

НідЫідНііпд Ехрегі... 

















Инструментальная среда СгузіаІ Перогіз 9 


11 


1.2. Редактирование объектов отчета 

В левой части главного окна располагаются три окна, предназначенные для 
создания, удаления и изменения объектов отчета — Керогі Ехріогег, РіеМ 
Ехріогег и Керозііогу Ехріогег. Следует отметить, что все три окна являются 
перемещаемыми и их можно расположить в любом месте главного окна 
СгузіаІ Керогіз 9. 

Окно Керогі Ехріогег (рис. 1.3) содержит древовидный список объектов от¬ 
чета. Верхний уровень дерева представляет собой отчет как таковой. На вто¬ 
ром уровне показаны секции отчета, на следующем показываются подсек¬ 
ции, если отчет содержит множественные секции. Подробнее работа 
с секциями, в том числе с множественными секциями будет рассмотрена 
в главе 6. Для каждой секции на нижнем уровне показываются содержащие¬ 
ся в ней объекты. 


йероИ Ехріогег _В 


■ Э- [*! беодгарНіс ЗаіегВероі! 

В- Щ Верой Неасіеі 

Ш Ц) Верой Неагіеі а ■' 

В- @ Верой Неасіеі Ь 

Іг ■ [д Раде Неадег 

сі : І2 бгоир Неасіеі #1 Г 

і? ; ■ • |Ш) Біоир Неасіеі Йіа: СиеЮпег.Сод? г 
В 0 Зіоир Неасіеі ВІЬ: Сиііотеі.Со—4; 
аЬ ТехМ: Юіоир #1 Ыате) 5 

■ аа РіеИЗ: Зит оі СизСоігіегІа.'ѵ:-' 

! В Щ 6гаирНеасіег#1с'. Си5(отеі.Со 

# ЭДШ 

; Е В бгоир Неасіеі МЛ Овіотеі.Со Щ 
'}■ ;• іаЬ . Т ехЙ: Ведіоп 

- ’ .зЬ Т ех*8: Сі*у 

.1.-*Ь Г««» Т і М-чг~~ 

■ІІ__!_ і 


Рис. 1.3. Диалоговое окно Верогі Ехріогег 

Керогі Ехріогег позволяет найти в отчете любой объект и изменить его свой¬ 
ства. Если переместить указатель на объект в списке Керогі Ехріогег и 
щелкнуть кнопкой мыши, то фокус автоматически установится на этом 
объекте. Это верно как в режиме Беы§п, так и в режиме Ргеѵіеіѵ. Для редак¬ 
тирования свойств объекта следует щелкнуть на нем правой кнопкой мы¬ 
ши — при этом появляется контекстное меню. Керогі Ехріогег позволяет 
также редактировать свойства группы объектов. Для выделения группы объ¬ 
ектов следует щелкнуть на них кнопкой мыши, одновременно нажимая кла¬ 
виши <Сіг1> или <5ЫЙ>. 

Окно ЕіеІД Ехріогег (рис. 1.4) также служит для редактирования объектов 
отчета, но в нем объекты сгруппированы не по размещению в секциях, а по 
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типу. В отличие от Керогі: Ехріогег, в окне Гіеігі Ехріогег можно создавать 
новые объекты. 


Ріекі Е хріотег _ Й 


ѵ У па ч і >• 

% В- ® ЬаіаЬазе . с іеІсІ5 '*■] 

|й-а І- 

; Щ 501 Ехріе$$іоп Гіекк 
Щ Раіатеіег ЕіеІсі$ 

;■ ■ 35 Виппіпд Тоіаі ГіеІгі$ 

’-Ѵ В Ж Сюир Мате РіеІск ,:-й ; 

Огоир Й1 Ыате. Си$1отег.Соипиу ; - 
^ біоир #2 №агпе: СизІотег.Ведіоп • ; 
бгоир ЙЗМате: Си$1отег.СНу 
Щ В “Ж $ресіа! Ріе1сі$ 

• аз Оаіа Оаіе ^ щ 

рК -ш» ОаІаТіте 

*' •• га ГііеДиіНог ^ 


Рис. 1.4. Диалоговое окно РіеІсІ Ехріогег 

С помощью Гіеій Ехріогег можно не только изменять свойства объектов, но 
и вносить их в любую секцию отчета. Подробнее работа с диалоговым ок¬ 
ном Еіеій Ехріогег будет рассмотрена в главе 2. 

Объекты отчета, например, запросы, функции, определенные пользовате¬ 
лем, или текстовые объекты могут иметь сложную структуру, и их создание 
иногда требует значительных трудозатрат. Очевидно, что такие объекты це¬ 
лесообразно использовать повторно. Сгузіаі КерогК 9 имеет специальное 
средство для повторного использования объектов в нескольких отчетах — 
хранилище объектов. Окно Керозііогу Ехріогег (рис. 1.5) служит для управ¬ 
ления хранилищем объектов — для размещения объектов, их организации 
в папках хранилища, вставки объектов хранилища в отчет и т. д. 


Рогтиіа Ріеіеіз 


Веро$ііогу Ехріогег 


:В ^ Сгузіаі Нерозйогу 
В {"3 Ітаде$ 

БВ Хиете Іодо 
05 Ро^егегі Ьу СгуйаІ Ьодо 
Ей ТейОЬіес* 
а В Оу$ІаІ Саге 
; а В СоруіідЫ 

■> а В РеесіЬаск Етай 

•аЬ Те$Л 
Ѳ-ЁЗ Соттапгі$ 

■Щ Си$1отегСЫег$5 Ьірресі 

т\ 

ВШ Тей 

аЬ Недіоп 


Етріоуееіпю 


Рис. 1.5. Диалоговое окно Веровііогу Ехріогег 

Подробнее работа с хранилищем объектов будет рассмотрена в разделе 2.10. 
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1.3. Использование подсказок 

Сгу$іа1 Кероп$ 9 имеет мощную систему контекстной справки (помощи). 
Для вызова помощи необходимо выполнить команду главного меню Неір | 
Сгузіаі Керогіз Неір или нажать клавишу <Р1>. Появляется диалоговое ок¬ 
но, содержащее текст подсказки (рис. 1.6). 


1 Е ? Сгузіаі Нерогіз Опііпе Неір 


ИНЕЗІ 
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п-:- 

1 • 1 гі .ѵя-і! 
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'?*- ВерогІ Ое$ідп Сопсеріз 
Іп^осіисііоп Іо ВероДіпд 
Оухізі Веро^йогу 
Оеіідпіпд ОрГгеей Ѵ/еЬ ВерогЬ 
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* Богііпд, Оіюиріпд. апсі Т оіаііпд 
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Я ф ІІпйег$Гапйіпдіиппспд(оІаІ8 
51 ф Оеаііпд шппіпд 1о(а1$ 

[7] Сгеаііпд гиппіпд Іо(аІ5 и$іпд а (очпиіа 
ф МиІІірІе ЗесПоп ВерогН 
РогтаІІІпд 
% СІіагІіпд 
ф Марртд 
ф СНЕ 

ф Сго85'ТаЬ ОЬІесЬ 
^ Сіеаііпд апс! СІрйаііпд ОІАР ВероЛх 


Затріе НерогЬк 

Тііе затріез іпзіаііей ѵѵіііі Сгузіаі Рерогіз 
діѵеуои ап ійеа оНРе сШТегет Іурез оі 
герогіз іііаісап Ье сгеаіей апсі Роѵѵіііеу 
Іоок іп ІІіа Рерогі Оезідпег. 

Тііеге із а затріе герогі іпзіаііесі ѵѵіІР 
Сгузіаі Рерогіз іііаі йетопзігаіез гиппіпд 
іоіаіз: 

• РиппіпдТоіаІз Огоир.грі 

Затріе герогіз аге Іосаіей іп іііе Сгузіаі 
Рерогіз йігесіогуипйег 
\5атр1ез\Еп\Керсн:Гз. 

Аййіііопаі затріе герогіз аге аѵаііаЫе ігот 
Ше Сгузіаі Оесізіопз Зиррогі ѵѵеЬ зііе; 

РКр://зиррсиі,г;іѵзіаІйесізюпз.сот/еатріез)' 


Сгузіаі Ресі5Іоп5 

СЗСм ККр ■^-^■■«>й.сгг.-яаМ-?с;г;огі;: сопл 

Зиррогі 5егѵісе5 


Рис. 1.6. Диалоговое окно Сгузіаі Вероііз Опііпе Неір 


Для поиска информации можно использовать индексированный список — 
вкладка Іпёех (Указатель), поиск — вкладка ЗеагсЬ (Поиск) или гиперссыл¬ 
ки. Контекстная подсказка вызывается нажатием клавиш <8Ый>+<Р1>. 

По команде главного меню Нері | АЬоиІ Сгувіаі Керогів дается подробная 
информация о версии Сгузіаі Керогіз. 



















Глава 2 



Создание стандартных отчетов 


2.1. Создание отчета с помощью 
Зіапсіагі Верогі Сгеаііоп ѴѴігагсі 

Сгузіаі КероПъ 9 содержит средства, позволяющие создавать отчеты пользо¬ 
вателям, не являющимся специалистами в области информационных техно¬ 
логий. Наиболее просто создание отчета с помощью мастера отчетов Керогі 
Сгеаііоп \Ѵіхаг<1. Мастер отчетов содержит несколько окон, в которых поль¬ 
зователю предлагается создать отчет в несколько шагов. 

1. Выбрать тип отчета. 

2. Выбрать источник данных для отчета. 

3. Связать таблицы источника данных. 

4. Создать поля отчета. 

5. Сгруппировать данные. 

6. Создать суммирующие поля для каждой группы. 

7. Сортировать данные отчета. 

8. Создать диаграммы на основании данных. 

9. Установить правила выборки данных. 

10. Выбрать шаблон форматирования полей отчета. 

Следовательно, мастер отчетов позволяет создавать сложные отчеты, кото¬ 
рые объединяют данные из разных таблиц баз данных, фильтруют данные 
по заданным критериям, группируют и сортируют их. Для создания нового 
отчета необходимо выполнить команду меню РПе | №\ѵ или щелкнуть на 
кнопке создания нового отчета (табл. 1.1). Открывается диалоговое окно 
СгузіаІ КероНв Саііегу (рис. 2.1). 

Первый шаг — выбор типа нового отчета. В диалоговом окне Сгуяіаі Керогів 
Саііегу можно выбрать один из четырех типов: 8іапйагй, Сго88-ТаЪ, МаіІ 
ЬаЬеІ или ОІАР. Далее будет рассмотрено создание стандартного отчета 
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8іап(]аг(1. Другие типы отчетов — матричный отчет Сго88-ТаЬ, отчет для пе¬ 
чати этикеток Маіі ЬаЬеІ и отчет на основе ОЬАР-источников данных ОЬАР 
будут рассмотрены в главе 6. После выбора типа создаваемого отчета 
8іап<ІапІ и щелчка на кнопке ОК в диалоговом окне Сгузіаі Керогіз Саііегу 
открывается мастер 8іап<1аг(1 Керогі Сгеаііоп ѴѴігапІ. 



Рис. 2.1. Диалоговое окно Сгузіаі Керогіз Саііегу 


8іап<1аг<1 Керогі Сгеаііоп \Ѵігагй содержит несколько последовательно откры¬ 
вающихся окон, которые позволяют шаг за шагом создать стандартный от¬ 
чет. Для перехода к следующему окну в мастере отчетов следует щелкнуть на 
кнопке N6x1, для возврата к предыдущему — на кнопке Васк. Если для соз¬ 
дания отчета достаточно информации, мастер отчетов делает доступной 
кнопку Ріпі8Іі. Щелчок на кнопке Гіпі8Іі закрывает мастер отчетов и откры¬ 
вает новый отчет в режиме просмотра. 

Первое окно мастера Баіа (рис. 2.2) содержит два древовидных списка. 
В левом списоке АѵаіІаЫе Баіа 8оигсе8 перечислены источники данных, ко¬ 
торые могут быть использованы для создания отчета. Доступ к базе данных 
может быть осуществлен с помощью 013ВС или драйверов прямого доступа. 
Правый список 8еІесіе<1 ТаЫез содержит выбранные таблицы источников 
данных. 

Рассмотрим создание отчета на основе базы данных, входящей в поставку 
СгузіаІ Керогй 9. Файл базы данных хІгете.шсІЪ после инсталляции СгузіаІ 
Керойз 9 находится в каталоге Рго§гат Рі1ез\Сгузіа1 Оесізіопз\Сгузіа1 Кероігз 9\ 
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Затр1е$\Еп\Оа{аЪа5е$. Для выбора хІгете.тйЬ в качестве источника данных 
следует переместить указатель на строку Сгеаіе Соппесііоп/ВаіаЬазе 
ИІев/Ріпй БаіаЬаке РНез левого списка и дважды щелкнуть кнопкой мыши. 
В появившемся диалоговом окне Ореп следует выбрать файл хІгете.тсІЪ 
и щелкнуть на кнопке Ореп. Затем необходимо переместить указатель на 
строку с наименованием таблицы и щелкнуть кнопкой мыши на кнопке >. 
Таблица будет внесена в правый список. 
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Рис. 2.2. Окно Ра1:а мастера ЗіапсіагсІ Вероіі Сгеаііоп ѴѴігагсІ 


Щелчок на кнопке открывает второе окно мастера Віапйагі Керог* 

Сгеаііоп \Ѵігапі (ІЛпк) (рис. 2.3). Если в качестве источника данных было 
выбрано более одной таблицы, в окне Ілпк показываются таблицы отчета 
в графическом виде — таблица изображается в виде прямоугольника, внутри 
которого содержится список полей таблицы. Индексированные поля поме¬ 
чены цветными маркерами. По умолчанию таблицы автоматически связы¬ 
ваются по полям с одинаковыми названиями. Связи таблиц можно удалять, 
создавать и менять их свойства. Подробнее связывание таблиц будет рас¬ 
смотрено в главе 7. Заметим, что если в качестве источника данных выбрана 
"настольная” база данных (например, формата ОВР или, как в рассматри¬ 
ваемом случае, база М5 Ассе$$), то связь между таблицами возможна только 
по индексированным полям. Для ООВС-источников данных такого ограни¬ 
чения нет. 
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Рис. 2.4. Окно Ріеісіз мастера Эіапсіагсі Рерогі Сгеаііоп ѴѴігагсІ 
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Третье окно мастера 8іапёаг<1 Керогі Сгеаііоп \Ѵіхагй (Ріеійв) содержит два 
древовидных списка (рис. 2.4). Левый список АѵаіІаЫе Ріе1сІ$ содержит поля 
таблиц, на основе которых могут быть созданы объекты отчета — поля 
(Ріеіеія) базы данных. Правый список Ріе1<1$ іо Бівріау содержит поля, кото¬ 
рые будут включены в отчет. Наименование поля в правом списке состоит 
из двух частей, разделенных точкой. Слева от точки показывается наимено¬ 
вание таблицы, справа — наименование поля, например, Сикіошег.Ьаяі 
Ѵеаг’8 Заіев. Для включения поля в отчет необходимо переместить указатель 
на строку с наименованием колонки и щелкнуть на кнопке >. 

Окно Стоирііц; (рис. 2.5) позволяет сгруппировать данные по какому-либо 
полю, причем сортировка групп может быть установлена по возрастанию 
значения поля (числового, строкового или даты), по убыванию или в специ¬ 
альном порядке. 
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Рис. 2.5. Окно Сгоиріпд мастера Зіапсіагсі Верогі Сгеаііоп ѴѴігагсі 


Левый список окна Сгоиріп§ — АѵаіІаЫе РіеЫ» содержит поля отчета и поля 
таблиц, на основе которых могут быть созданы группы отчета. Правый спи¬ 
сок Сгоир Ву содержит группы отчета. Для создания в отчете новой группы 
необходимо в левом списке переместить указатель на строку с наименова¬ 
нием поля отчета, по которому будет проведена группировка, и щелкнуть 
кнопкой >. В рассматриваемом примере (рис. 2.5) данные отчета будут 
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сгруппированы сначала по странам, внутри каждой страны по регионам и, 
наконец, внутри каждого региона по городам. 

Подробнее группирование данных отчета будет рассмотрено в главе 3. 

В Сгуйаі К.ероП$ 9 можно вычислять суммарные значения числовых полей 
в каждой группе. Например, если в отчет включено поле СивІотег.Ьаві 
Ѵеаг’8 8а1ев (продажи клиенту в прошлом году) и в отчете созданы группы 
по странам, регионам и городам, можно вычислить объемы продаж в каж¬ 
дом городе, регионе и стране. Вычисляться могут не только сумма, но и 
среднее значение, количество клиентов и другие агрегатные значения. Для 
вычисления агрегатных значений служит окно Зшшпагіев (рис. 2.6). 
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Віоілкде ОаІа . Рігкі РіеИ, 


< Назад ' І” Далее > . | ' ; Го)міпііпит 

. : -}.Ф.?Г7Т- Соип( 


Аѵе?аде 
Затріе ѵаоапсе 
Затріе $1апс3агсі сіеѵіаНоп 
Махітит 


Рис. 2.6. Окно Зиттагіез мастера ЗіапйагсІ Рероіі Сгеаііоп ѴѴігагсІ 


Левый список окна Зшшпагіе8 содержит поля отчета и поля таблиц, на ос¬ 
нове которых в отчете может быть проведено агрегирование данных. Пра¬ 
вый список Зшшпашей РіеИн содержит древовидный список отобранных 
для вычисления агрегатных значений полей. В правой нижней части окна 
расположен раскрывающийся список агрегатных функций (суммирование, 
вычисление среднего, максимального и минимального значения, подсчет 
количества записей и т. д.). В примере на рис. 2.6 будет вычисляться коли¬ 
чество клиентов в каждой стране и сумма продаж в каждой стране, регионе 
и городе. 
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Рис. 2.7. Окно Сгоир Зоіііпд мастера ЗІапРагР Перогі Сгеаііоп ѴѴігагсі 



Б Зіапсіаггі Нерогі Сгеаііоп Ѵ/ігані 


(Орііопаі) ІпсЫе а сНагІ оп іЬе герогі 


|Ж СизІотег.СоипІгу 


:ЗНой«игшаѵ 


Рис. 2.8. Окно СНагІ мастера ЗіапсіагсІ Нерогі Сгеаііоп ѴѴІгагсІ 
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Гпава 2 


Окно (тгоир 8огііп§ мастера ЗДапЛапІ Керогі Сгеаііоп \ѴІ 2 агіІ (рис. 2.7) позво¬ 
ляет более эффективно обрабатывать сгруппированные данные. В верхней 
части окна расположен раскрывающийся список, содержащий группы, уже 
созданные в отчете с помощью окна Сгоирш§ (рис. 2.5). Радиокнопки 
в средней части окна позволяют выбрать тип группировки, а раскрываю¬ 
щийся список в нижней части — выбрать критерий отбора групп. Так, 
в примере на рис. 2.7 выбор специальной группировки Тор 5 §гоир$ и зна¬ 
чения суммы 8шп оГ Си8Іотег.Ьа$1 Ѵеаг’8 8а1е§ в качестве критерия позво¬ 
лит оставить в отчете только те страны, которые занимают пять первых мест 
по объему продаж. Более подробно возможности агрегирования и специаль¬ 
ной группировки будут рассмотрены в главе 3. 

Окно СЬагІ (рис. 2.8) предназначено для включения в отчет диаграмм трех 
типов — диаграммы в виде столбцов (Ваг), линий ГТіпе) и секторные диа¬ 
граммы (Ріе). 

Диаграммы могут быть созданы только в отчете, содержащем группировку 
данных и вычисление агрегированных значений для этих групп. Окно СЬагІ 
содержит поле СЬагІ ШІе для внесения заголовка диаграммы, списки Оп 
еЬаіще оГ и 8Ьо\ѵ 8шшпагу, в которых следует выбрать группу и агрегирован¬ 
ные данные для диаграммы. 


I ЗіапгіаісІ Вероіі Сгеаііоп Ѵ/ігаг<1 


Весоігі Зеіесііоп 

(ОргіопаІ) 5еІес( а $иЬ$е( іп&шаНоп (о сй$рІау. 


: -&ѵараЬ!е РіеЙ$:: 


0 ВерогіРіе!сі§ [ 

: аз, Сизіотег. Сироте» Мате ; 

) * *... нэ. Си$Ютег.І_а$1 Ѵеаг'$ Заіег 

• аз Си$ІотесВедіоп 

{ ;• аз Си$Іотег.Сііу 

: аз Си$1отег.Си$*отег Ю 

Ё- Ш Си$(отеі 

І ев Сийотег Ю 
5 - • из Си$*отег Ю 
! аз Си$*отег Мате 

! аз Соп*ас* Рігзі Мате 

) -аз- Соп*ас* І_а$1 Мате 
і- - из Сопіас* ТіНе 
г еѳ Сопіасі Ро$ійоп 
<1 - - -д. : 



< Йаск I Цех! > I ЯпвЬ Сапсеі 


Рис. 2.9. Окно Песогсі Зеіесііоп мастера ЗіапсІагсІ Вероіі Сгеаііоп ѴУігагсІ 
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Окно Кесогй Зеіесііоп (рис. 2.9) служит для создания правил отбора данных 
в отчет и содержит два списка. Левый древовидный список АѵаіІаЫе РіеІсІ8 
содержит все доступные поля таблиц базы данных. Правый список РіІІег 
Ріеіск содержит поля, на основе которых создаются правила отбора данных 
в отчет. Для включения поля в правый список из левого необходимо пере¬ 
местить указатель на строку с наименованием колонки и щелкнуть на кноп¬ 
ке >. Например, пусть в отчет следует внести не всех клиентов, а только тех, 
кто в прошлом году сделал покупок более чем на 1000$. Для этого надо пе¬ 
ренести поле Ьа8І Ѵеаг’я 8а1е« из левого списка в правый и в раскрываю¬ 
щихся списках в правой нижней части окна задать логическое условие — 
предикат і$ §геаіег Ійеп (больше чем) и числовое значение 1000 (рис. 2,9). 
Если строка удовлетворяет заданным условиям, она включается в отчет. 
Предикаты, установленные для различных полей, объединяются логическим 
"и". Список выбора в правой нижней части окна контекстный, т. е. его со¬ 
держание — логические условия — зависит от типа выбранного поля. Более 
сложные условия отбора данных можно установить в диалоговом окне Зеіесі 
ЕхреіТ, которое будет рассмотрено в главе 3. 

Последнее окно мастера Зіагкіапі Керогі Сгеаііоп ѴѴіхапІ — Тешріаіе служит 
для выбора шаблона форматирования отчета. Список в окне Тешріаіе со¬ 
держит десять шаблонов. В примере на рис. 2.10 выбран шаблон СопПйепІіаІ 
ТГпёегІау. 


[і іі' іі ..іи нпі — 



Т етріаіе 
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(Ор(іопаІ) ЗеІесІ а (етріаіе (ог (Не іероіі. 
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Рис. 2.10. Окно Тешріаіе мастера 51апсіагсі Вероіі Сгеаііоп ѴѴігагсІ 
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Гпава 2 


После щелчка на кнопке РіпізЬ (Готово) можно просмотреть созданный от¬ 
чет на вкладке Ргеѵіеіѵ главного окна Сгу$іа1 Керогіз 9 (рис. 2.11). 



Рис. 2.11. Просмотр на вкладке Ргеѵіеѵѵ отчета, созданного 
с помощью мастера Зіапсіагсі Верогі Сгеаііоп ѴѴігагсІ 


Упражнение 2.1 

1. Выполните команду меню Рііе | N6». 

2. Выберите в диалоге Сгувіаі Кероіі баііегу стандартный отчет Зіашіагй. 

3. В окне Паіа мастера создания отчетов в качестве источника данных вы¬ 
берите Сгеаіе №ѵѵ Соппесйоп/ ПаіаЬазе Рііез. 

4. В диалоге Орел (открытие файла) укажите файл Ргоехат 
Рі1ез\СгузИІ Оесізюпз\Сгузт1 Яерогіз 9\5атр1е$\Еп\раіаЪа$е8\хІгете.тсІЪ. 

5. После включения базы данных хігете в список источников выберите 
в разделе ТаЫе$ таблицу Сивіотег и щелкните на кнопке >. Таблица 
Сизіотег включается в правый список Зеіесіей ТаЫе8. Щелкните на 
кнопке N6x1 (Далее). 
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6. В окне РіеЫз включите в отчет поля Сивіотег №те и Ьаві Уеаг’в Заіея. 
Щелкните на кнопке N6x1 

7. В окне Сгоиріп§ включите в отчет группировку по полю Сііу. 

8. Щелкните несколько раз на кнопке N6x1 до тех пор, пока не появится 
окно Кесогй 8еІесііоп8. 

9. В окне Кесоггі Зеіесііопв задайте условие отбора Сошіігу І8 ечиаі Іо ІІ8А. 

10. Щелкните на кнопке РіпіаЬ. 

11. Сохраните отчет. 

2.2. Вставка в отчет и форматирование 
полей базы данных 

Рассмотрим, как выглядит отчет на вкладке Ве8І§п. Большая белая область 
в середине вкладки разделена на секции горизонтальными линиями 
(рис. 2.12). При добавлении секции в отчет, например, при группировке 
данных, Сгузгаі Ксрогй 9 автоматически добавляет линию. Серая область 
слева содержит дополнительную информацию, помогающую работать с дан¬ 
ными и объектами. Горизонтальные линии продолжаются в серую область, 
определяя секции, и Сгузіаі Яеропз 9 идентифицирует каждую секцию по 
аббревиатуре или выбранному имени. 
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Рис. 2.12. Представление отчета на вкладке Рееідп 
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Гпава 2 


Секция заголовка отчета Кероп Неабег (КН) изображается единожды в са¬ 
мом начале отчета. Секции Ра§е Неабег (РН) и Ра§е Рооіег (РР) показыва¬ 
ются на каждой странице и обычно используются для заголовков, нумера¬ 
ции страниц и т. д. Секция Оеіаіі (О) — это основное содержание отчета. 
Секция Кероіі Рооіег (КР) показывается единожды в самом конце отчета. 

Для внесения в отчет полей базы данных, специальных полей, формул 
и параметров служит диалоговое окно Ріеіб Ехріогег (рис. 1.4), содержащее 
панель управления и древовидный список объектов отчета. Элементы 
управления панели инструментов диалогового окна РіеЫ Ехріогег приведены 
в табл. 2.1. 


Таблица 2. 1 . Элементы управления панели инструментов 

диалогового окна РіеШ Ехріогег 


Элемент Описание элемента 

управления 





Внесение выбранного объекта в отчет 


Просмотр содержимого поля базы данных (первые 100 неповто¬ 
ряющихся значений) 

Создание объекта 
Редактирование объекта 
Переименование объекта 
Удаление объекта 


При внесении в отчет поля базы данных (раздел списка БаІаЬазе ЕіеШ) дос¬ 
тупны только первые две кнопки. Для внесения поля в отчет нужно выбрать 
поле в списке, щелкнуть на кнопке внесения объекта и затем щелкнуть на 
свободной части какой-либо секции отчета. Можно также перенести поле из 
списка в секцию отчета методом Ога§&Пгор. 

Существует три варианта выбора поля для отчета. 

□ Выбрать индивидуально поле, щелкнув на нем, и поместить его в нужное 
место отчета. 

□ Выбрать диапазон полей, щелкнув на первом поле и щелкнув на послед¬ 
нем при нажатой клавише <$ЫГі>. 

□ Выбрать группу полей, щелкнув на первом поле и щелкнув на каждом 
дополнительном при нажатой клавише <Сіг1>. 
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Поля будут размещены в порядке списка, но не в порядке выбора. Размер 
поля в отчете зависит от размера поля в базе данных: Если поле размещено 
в секции Беіаіі, в секцию Ра§е Неадег одновременно вносится текстовый 
объект — заголовок поля, который представляет собой название поля в базе 
данных. 

Упражнение 2.2 

1. Откройте отчет, созданный в упражнении 2.1. 

2. Внесите в секцию отчета ОеіаіІ следующие поля таблицы Сизіотег: 

• Сопіасі ЬаЛ №те 

• Сопіасі Ріг5І Кате 

• СопГасГ ТШе 

3. Сохраните отчет. 

Для просмотра полученного отчета на вкладке Ргеѵіе\ѵ следует щелкнуть на 
кнопке просмотра отчета (табл. 1.1) на панели инструментов. Отметим, что 
строка состояния Ъаг в режиме Ргеѵіеѵѵ показывает количество вы¬ 

бранных и общее число прочитанных записей. 

Сгузіаі Кероітз 9 позволяет изменить порядок расположения полей отчета. 
Для этого можно просто перенести поле внутри секции или между секция¬ 
ми методом Ога§&Огор. Можно также сразу перенести группу полей. Для 
этого нужно предварительно выбрать их, щелкнув в каждом, одновременно 
нажимая клавишу <51іШ> или <СГг1>. 

Для более тщательного форматирования полей предназначается специаль¬ 
ный инструмент (гшёеііпез (опорные линии), к которым можно привязать 
поля отчета. Для отображения Стіі<іе1ше$ нужно выполнить команду меню 
Рііез | Орііош и на вкладке Ьауоиі диалогового окна Орііопз включить опции 

СшЛеНпез. 


У 

! • 1 * 2 • і • 3 • * • 4 • * - 5-1 * '7 

т> 

ъ 



#Соп!асі 1_азі №те} ; 

- 


Рис. 2.13. Форматирование полей с помощью опорных линий Сиісіеііпее 


При форматировании поля его левый край подводится к опорной линии 
(а не наоборот!). То, что поле связано с опорной линией, показывают не¬ 
большие красные метки по периметру поля. Если с одной линией связаны 
несколько полей, то перемещение опорной линии в верхней или левой ли¬ 
нейке форматирования (рис. 2.13) приводит к перемещению группы полей 


2 Зак. 1021 
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Глава 2 


по горизонтали или по вертикали соответственно. Если привязать правый 
край поля, то с помощью опорной линии можно изменить его размер. 

Создать новую опорную линию можно, дважды щелкнув по линейке форма¬ 
тирования. Удалить опорную линию можно, переместив ее (Бга§&Бгор) из 
линейки форматирования. 

Упражнение 2.3 

1. Откройте отчет, созданный в упражнении 2.2. 

2. Передвиньте поле и заголовок поля Сйу одновременно. 

3. Щелкните по полю Сііу и выделите его. 

4. Нажмите клавишу <СТг1> и щелкните по заголовку этого поля. Оба поля 
теперь имеют рамку. 

5. Перенесите Сііу в левую часть отчета. 

6. Сохраните отчет. 

Таким же способом можно передвигать любые другие поля. На рис. 2.14 по¬ 
казан отчет, который должен получиться после выполнения упражнения. 


СНУ 

АМаійа 

21.04.03 

ОиШжШт 

ЬазІѴеаг'е ЗаІезСопіасі ТНІа СолІасІРгаі 

е-рыар.иаі. 

АІІапІа 

Топу'з Вейег Вікез 

2 735,25р. м < 

АпОіопу 

ѵѵеаінеіьеай 

АМаМа 


2 735,25 р. 



Аикііп 





Аигііп 

РоскзЬоскз Тог ^скз 

40 778,52р. М5 

НеаіИег 

Оаѵіг 

Аибііп 


40 778,52 р. 




Рис. 2.14. Представление отчета на вкладке Ргеѵіеѵѵ 
после выполнения упражнения 2.3 


Если создать отчет и затем сохранить или закрыть его, СгуМаІ КероПз 9 по 
умолчанию вместе с ним сохраняет данные. Если после этого открыть отчет, 
он будет содержать сохраненные данные. Для принудительного обновления 
данных следует выполнить команду меню Керогі | КеГгеДі Керогі Ба Іа либо 
нажать клавишу <Р5>. 

Для форматирования поля служит диалоговое окно Рогтаі Е<Шог (рис. 2.15), 
которое можно вызвать, щелкнув правой кнопкой мыши на поле и выбрав 
в контекстном меню пункт Рошіаі ГіеІФ Вкладки диалогового окна Рогіпаі 
Егійог позволяют задавать свойства полей безусловно (поля выбора) или по 
условию (кнопки вызова редактора формул справа от каждого условия). 
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С помощью редактора формул можно создать формулу, возвращающую ло¬ 
гическое значение "истина" или "ложь". При выполнении условия (значение 
"истина") форматирование будет выполняться, в противном случае — нет. 
Синтаксис формул будет рассмотрен в главе 5. Так, опция 8иррге$$ позволяет 
скрыть поле. Например, задав формулу, можно скрывать только поля, содер¬ 
жащие значения меньше 1000. Создание формул будет рассмотрено далее. 



Рогтаі Егіііо» 


й - . 


Соттоп )в«йег ].РоЛ ) РаіадіарЬ | НурЫпк ] ■ 

-0Ь|ес1 (оіта( 

. ОЬ|есіКате: ]Сопіас1а5ЙатёІ 

С55С}юіЫ*г». } 

Г~ ВеаДоЫу • . Г” Іоск Ео*Люгіапсі 5іге 

П 8цррге$5 . 

"Г"**"* |м "' ^ й 

У аѵ&ЪпПѵЪе*. 

Г- 


ІооІТірТехІ 
ТЫ Воіаіюгс. 


Рис. 2.15. Вкладка Соттоп диалогового окна Рогтаі Есіііог 

Вкладка Соттоп диалогового окна Рогтаі Е(Шог (рис. 2.15) содержит сле¬ 
дующие опции форматирования: 

□ Кеер Оіуесі То§еІЬег — запрет на разрыв объекта при переходе на новую 
страницу. Если эта опция выбрана, то объект, не умещающийся на теку¬ 
щей странице, будет перенесен целиком на следующую страницу; 

□ СІозе Воггіег оп Ра§е Вгеак — если объект не умещается на текущей стра¬ 
нице и переносится на следующую частично, т. е. разрывается на две 
части и каждая часть обрамляется рамками полностью; 

□ Сап Сготѵ — расположение текста объекта в несколько строчек; 
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□ Тооі Тір Тех* — создание ярлыка объекта, ярлык появляется в режиме 
просмотра; 

□ Тех* Ко*а*іоп — вращение объекта, допускается горизонтальное или вер¬ 
тикальное размещение объекта; 

□ Зирргезз ІГ Биріісаіеіі — если значение поля повторяется несколько раз, 
то показывается только первое значение, остальные скрываются. 

Вкладка Вогііег позволяет создать рамку для объекта. На вкладке Роп* можно 
установить размер, стиль и цвет шрифта. 

Вкладка Рага^гарН Рогша*іп§ служит для форматирования текста, если он 
расположен в несколько строк. 

С помощью вкладки Нурегііпк (рис. 2.16) можно установить гиперссылку на 
другой объект текущего отчета, \ѴеЬ-сайт, адрес электронной почты или на 
другой отчет. 



Солтоп ) Вогсіег] Роп< | РагадіарИ Нурегііпк } 

- Нурегііпк Іуре - - 

- № Нурёібпк • ' С. Ап Е-таіІ Асііек ч ; 

■ С Ау/еЬзііеопІНеІпІетеІ ^ АИІе 

С Си[іеп*' , ѵѴ'еЬІІеИеИѴаЬе СитепЕЕ-таіІГіййув 

I - ' РНТМІ Ѵіеиеі Оп!у 

С -- _ , п С АгюіЬе*ВерогіОЬ|ес1 


ГреЫат* ' - • 

* ***' і- л ~ч. ,('■ ѵс>у ' х л 

I ;'п 9\Затріез\Еп\Яерс[(к''АЬсиІ (Не $|атрІе ВерогІз.гІГ 


НеІрМНтІ - - - - - - 

Іі$е іНіз Іуре о! Нурегііпк Іо Ііпк Іо аЙе опуоиг сотргіег рі уоиг огдагіігайоп'з 

пвіілгагк. Сгузіаі Верогіз иіВ ІаипсН 1Ьё аззосвЫ арріісаііоп Гог (Ыз ІІІе, 

й«е ІНе Іогтиіа Ьиійні (о сгеаіе а Ьуреіііпк ГЬаі з Ьазесі оп сіаіа (гот а ГіеИ іп 
уоиг сіаіа зоигсе ; " . ѵ і 


Рис. 2.16. Вкладка Нурегііпк диалогового окна Рогтаі ЕсШог 


В группе радиокнопок Нурегііпк *уре задается тип гиперссылки. В области 
Нурегііпк Іпіогша*іоп для каждого типа гиперссылки следует внести допол- 
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нительную информацию. В табл. 2.2 приведены возможные типы гиперссы¬ 
лок, которые можно установить для объекта отчета в Сгуыаі ЯерогК 9. 

Таблица 2.2. Элементы управления панели инструментов 

диалогового окна РіеШ Ехріогег 

Тип Описание Содержимое раздела 

гиперссылки Нурегііпк іпіогтаііоп 

N 0 Нурегііпк Отказ от гиперссылки для выбран- Раздел недоступен 
ного объекта, опция по умолчанию 

Ссылка на адрес в Интернете. Адрес Поле ѴѴеЬзііе Асісігезз, 
может быть статичным или в котором следует внести 

генерироваться динамически с адрес ѴѴеЬ-сайта (ІШІ.) 

помощью формулы (кнопка справа 

от поля ѴѴеЬзііе Асісігезз, подробнее Кнопка вызова редактора 
о создании формул см. гл. 5), формул 

например: "Нйр://ѵѵѵѵѵѵ." + 

{СизІотег.СизІотег Ыате} + ".сот" 

Сиггепі ѴѴеЬзііе Ссылка на адрес в Интернете, хра- Раздел недоступен 
Ріеісі Ѵаіие нящаяся в базе данных. Адрес дол¬ 

жен храниться в выбранном поле 

Ссылка на адрес электронной поч- Поле Е-таіІ Асісігезз, в 
ты. Адрес может быть статичным котором следует внести 
или генерироваться динамически с адрес электронной почты, 
помощью формулы Кнопка вызова редактора 

формул 

Поле РИе Мате, в кото¬ 
ром следует внести имя 
файла и путь. 

Кнопка вызова редактора 
формул 

Сиггепі Е-таіІ Ссылка на адрес электронной почты, Раздел недоступен 
Ріеісі Ѵаіие хранящийся в базе данных. Адрес 

должен храниться в выбранном поле 

АпоіНег Перогі Ссылка на объект текущего или В поле Зеіесі Ргот сле- 
ОЬ)есІ какого-либо другого отчета. Если дует указать путь и имя 

ссылка настроена на другой отчет, файла отчета, на который 
не текущий, он будет загружен в создается ссылка, 
СгузІаІНерогІз 9 и выполнен в поле ОЬ|есІ Мате- 

имя объекта отчета, 
в Раіа Сопіехі— значение 
поля, на которое будет 
установлен указатель, 
например: /СоипІгу[ІІ5А]/ 
Ргосіисі Сіазз[ВісусІе] 


А Рііе Ссылка на файл, хранящийся на 

локальном компьютере или в сети. 
Имя файла и путь могут быть ста¬ 
тичными или генерироваться дина¬ 
мически с помощью формулы 


Ап Е-таіІ 
Асісігезз 


А ѴѴеЬзііе оп 
ІНе Іпіегпеі 
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Таблица 2.2 (окончание) 

Тип 

гиперссылки 

Описание 

Содержимое раздела 
Нурегііпк іпіогтаііоп 

Яерогі Рагі 
ОгіІИоѵѵп 

Выполняет ту же функцию, что и 
"высверливание" данных (ОгіІІ Ооѵѵп, 
см. разд. 6.3). Опция работает толь¬ 
ко в текущем отчете 

Раскрывающийся список 
0Ь|ес1 Ыате, в котором 
следует выбрать наиме¬ 
нование объекта, на ко¬ 
торый будет установлен 
указатель 


Упражнение 2.4 

Увеличьте шрифт поля Ьа8і Уеаг’в 8аІе8 до 14 пунктов. 

1. Откройте отчет, созданный в упражнении 2.3. 

2. Щелкните в поле заголовка для его выделения. 

3. Правой кнопкой мыши щелкните в поле и выберите Рогшаі РіеІФ 

4. В диалоге Рогшаі Ейііог выберите вкладку Ропі и установите размер 14. 

5. Сохраните отчет. 

Сгузіаі Кероп.5 9 позволяет включить в отчет изображения, хранящиеся в базе 
данных (рис. 2.17). Для этого нужно просто включить в отчет поле базы данных, 
в котором хранится изображение. Сгузіаі Яерогіз 9 автоматически распознает 
большой бинарный объект как изображение и поместит его в секции отчета. 


Примечание 

В пакет Сгузіаі Перогіз 9 входит отчет, иллюстрирующий возможность включе¬ 
ния таких изображений. Его местонахождение: Ргодгат НІез\СгузІаІ Оесізіопз\ 
Сгузіаі Нерогіз 9\ЗатрІез\Еп\ЯерогІ5\ОепегаІ Визіпезз\ЕтрІоуее Ргоіііе.грі. 



09.34.32 10.26 * М: і 


Егпр(о}>ееРіо1іІ* 


Мапсу Ватоію 

ГІмІйіРсзпіпи: Баіез Йер'езепіэбѵѳ 

С хіе«л»оп: 545? 

ЖЙЬМоте РПопш &^(206)555-9е57 

><ѵко**. 

ЙІ'-сй Нотч АіМвМЧ Ѵ#Л ■ 2011» Ал Е 

«ШШ 

: ^ОЛ Моо4/. 3С 
с агшс|а 

. 


«Ншяз: 


Егіосаііоп тсіисіев а ВАт РзусЬоІоду Ігогг, С'оіогасіо Бізіе ІІліѵв/гіІу ю 1994 ЗЬѳ зізо сотр1ѳ!е4 ПЬе 
АД оГ іЬе Соігі СэИ." №псу к а тетЬег оГТоазіпэзІегз ІпіетаНопаІ 




Раѵоііо, Ыапсу 


Рис. 2.17. Пример отчета, который содержит изображение, 
извлекаемое из базы данных 
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Упражнение 2.5 

1. Используя в качестве источника данных таблицу Етріоуее, создайте отчет 
и включите в него поля Рігв! ІЧате, Ьаз! №те, РЬо!о. 

2. После выполнения данного упражнения вернитесь к отчету в упражне¬ 
нии 2.4. 

2.3. Вставка в отчет 
текстовых объектов 

Для вставки текстового объекта нужно щелкнуть на кнопке вставки тексто¬ 
вого поля на панели инструментов (табл. 1.1) или выполнить команду меню 
Іпзег! | Тех! Оіуес!. После этого следует щелкнуть на свободном месте в сек¬ 
ции отчета, например, Ра§е Неагіег. Вставить текстовый объект можно как 
в режиме Ргеѵіеѵѵ, так и в Бе8І§п. 


А . 

' ■ 2 • 1 '• 3 Л .-/ 

реаг | 

і_і 


Рис. 2.18. Текстовый объект 


После размещения текстового объекта Сгузіаі КерогК 9 переходит в режим 
редактирования. При помощи клавиатуры можно набрать текст, а в верхней 
части экрана появляется окно форматирования текстового объекта 
(рис. 2.18). Можно импортировать текст из текстового файла. Для этого 
в режиме редактирования следует щелкнуть правой кнопкой мыши на тек¬ 
стовом объекте и выбрать из контекстного меню Іп$егі Ргога Рііе. Поддер¬ 
живается импорт из файлов форматов А8СІ1, НТМЬ и М8 \УопІ 

Текстовый объект в Сгузсаі КероіТз 9 может содержать не только текст, но и 
поля базы данных, формулы, специальные поля и параметры (рис. 2.19). 
Чтобы внести в состав текстового объекта новое поле, нужно сначала соз¬ 
дать его в какой-либо секции отчета, а затем, находясь в режиме редактиро¬ 
вания, переместить его Шгад&Огор) внутрь текстового объекта. 

Для того чтобы изменить свойства текстового объекта, необходимо выйти из 
режима редактирования (щелкнув на любом другом поле отчета) и щелкнуть 
на нем правой кнопкой мыши. В появившемся контекстном меню следует 
выбрать Рогта! Тех!. Диалог Рогта! Ейі!ог, служащий для редактирования 
свойств текстового объекта, полностью аналогичен соответствующему диа¬ 
логу для редактирования свойств поля базы данных. 
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і*1* і • 2 • і 1 3 • і • 4 * і • б ■ і -6*і • 7 • і * 8 ■ і*9* і • 10 * I • 11 < і *1&. 


ре аг {Сопіасі ТШе} {СопГай Рігзі Мате} {Сопіасі [_а$1 №те}] : 


Рис. 2.19. Текстовый объект, содержащий поля базы данных 

Для возвращения в режим редактирования следует дважды щелкнуть на тек¬ 
стовом объекте. 

Если текстовый объект содержит поля базы данных, специальные поля или 
формулы, то в режиме редактирования можно задавать свойства для каждого 
из подобъектов отдельно. 

Упражнение 2.6 

1. Откройте отчет, созданный в упражнении 2.4. 

2. Выполните команду меню Іпзегі | Техі ОЬ]ес1. 

3. Щелкните на свободном месте в секции Ра$»е Неайег. 

4. Наберите "Отчет по продажам". 

5. Установите для текстового объекта полужирный стиль и размер шрифта 14. 

6. Сохраните отчет. 

2.4. Вставка в отчет 
специальных полей 

Помимо текстовых полей, в отчет могут быть включены специальные поля, 
содержащие дополнительную информацию, такую как номер страницы, 
номер записи, дата отчета и т. д. Для вставки специального поля необходи¬ 
мо в списке полей диалогового окна РіеМ Ехріогег выбрать раздел 8ресіаІ 
Ріеігі (рис. 2.20). 

Группа полей 8ресіа1 Ріеігі содержит следующие специальные поля. 

□ Ра§е ГѴшпЬег — номер страницы. Обычно размещается в секциях отчета 

Ра§е Неагіег или Ра§е Рооіег. 

□ Тоіаі Ра§е Соиій — общее количество страниц в отчете. Это поле может 
быть использовано в любой секции отчета. Например, ТоіаІ Ра§е Соипі 
может быть использовано для создания текстового объекта "Итого стра¬ 
ниц в отчете — У" или "страница X из У", где X — Ра§е №ипЬег, У — 
ТоЫ Ра§е Соипі. Включение этого поля в отчет может привести к увели¬ 
чению времени формирования отчета, поскольку в этом случае Сгузіаі 
Кероііз 9 при переходе на вкладку Ргеѵіеіѵ формирует все страницы отчета. 
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Яек) Ехріогег _ ЕЗ 


^ щр | 'Е ѵ «ч. X 

В -5Ё ЗресіаІ РіеИ$ 

: аз Эаіа Эаіе 
ош 0.з(д Тіте 


Рііе АіЛЬоі 


■та Рііе Сгеа^іоп Оа^е 
■ оэ Рііе РаНз апс) Ыате 
■та ОтирЫигпЬег 
оз бшир 5еІесІ ; оп Ро(гпиІа 
оз МогііКсаііоп йаіе 
та МосбЙсаИоп Тіте 
таѵ Раде N о( М 
Раде ЫитЬег 
та Рті Оаіе 


Рис. 2.20. Группа полей 5ресіа1 Ріеісіз в списке диалогового окна Ріеісі Ехріогег 

□ Ра§е N оГ М — показывает номер текущей страницы из общего количест¬ 
ва страниц в отчете. Например, если в режиме просмотра значение этого 
поля — "Ра§е 2 оГ8", то показана вторая страница из восьми, входящих 
в отчет. 

□ Керогі ТШе — заголовок отчета. Это поле может быть использовано 
в любой секции отчета. Конечно, в качестве заголовка отчета можно ис¬ 
пользовать и текстовый объект. Использование специального поля Керогі 
ТШе в качестве заголовка позволяет задать его значение из меню Рііе | 
Зшшпагу Іпіо. В результате значение Керогі ТШе будет свойством отчета 
и может быть использовано как параметр при вызове отчета из клиент¬ 
ского приложения, написанного на Оеірііі, М$ Ѵіхиаі Вале или С++. 

□ Керогі Соттепі$ — комментарий к отчету. Использование этого поля 
аналогично использованию Керогі ТШе. Длина поля ограничена 256 сим¬ 
волами. 

□ Рііе РаіЬ апгі ^те — имя файла отчета и путь к нему. 

□ Рііе Аиііюг — имя автора отчета. Задается в диалоговом окне Воситепі 
Ргорегііе«, которое вызывается при помощи команды меню Рііе | 
Зшшпагу ІпГо. 

□ Рііе Сгеаііоп Баіе — дата создания шаблона отчета. По умолчанию при¬ 
сваивается системная дата компьютера, на котором создается отчет. 

□ Ргіпі Баіе — дата печати отчета. Может быть изменена командой меню 

Керогі | Зеі Ргіпі Баіе | Тіте. 

□ Ргіпі Тіте — время печати отчета. Может быть изменено командой меню 

Керогі | .Зеі Ргіпі Баіе/Тіте. 

□ Баіа Баіе — дата последнего обновления данных (геГгезЬ). 
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□ Баіа Тіше — время последнего обновления данных (геГге$Ь). 

□ МоШЯсайоп Баіе — дата последнего изменения шаблона отчета. 

□ МогііЯсайоп Тіте — время последнего изменения шаблона отчета. 

□ Кесоггі ІЧшпЬег — номер записи отчета. Может быть использован только 
в секции Оеіаі]$. 

□ Стоир ІЧитЬег — номер группы отчета. Может быть использован только 
в секциях Сгоир Неагіег или Сгоир Рооіег. 

□ Кесоггі 8еІесйоп Рогтиіа — поле отображает в режиме просмотра форму¬ 
лу, использующуюся для отбора записей. Более подробно создание фор¬ 
мул и выборка записей будут рассмотрены в главе 5. 

□ Сгоир Зсіесііоп Рогтиіа — поле отображает в режиме просмотра формулу, ис¬ 
пользующуюся для отбора записей (фильтрация по агрегатным значениям). 

2.5. Вставка в отчет параметров 

Часто необходимо запускать отчет с минимальными изменениями. Для 
обеспечения таких изменений без редактирования отчета предназначены 
поля параметров. Значение параметра может быть задано пользователем пе¬ 
ред выполнением отчета. 

Использование параметра в отчете включает три стадии. 

1. Создание поля параметра. 

2. Включение параметра в отчет, например, в условие выборки или в фор¬ 
мулу. 

3. Задание параметра при выполнении отчета. 

При создании параметра необходимо ввести его имя, тип, сопровождающий 
текст, набор значений и значение по умолчанию. Имя параметра в отчете 
будет показываться как {?Рагатеіе^ате}. Допускаются следующие типы 
параметров: 

□ ИитЬегУаг — число; 

□ СиггепсуѴаг — валюта; 

□ ВооІеапѴаг — логический (Вооіеап); 

□ ОаіеѴаг — дата; 

□ ОаіеТітеѴаг — дата и время (Тішезіатр); 

□ ТітеѴаг — время; 

□ 5ігіп§Ѵаг — строка. 

Допускаются диапазоны значений параметров и множественные параметры. 
Для создания параметра необходимо в списке полей диалогового окна Ріеій 
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Ехріогег переместить указатель на строку Рагашеіег Ріеігі и щелкнуть кноп¬ 
кой мыши на кнопке создания объекта (табл. 2.1). В появившемся диалого¬ 
вом окне Сгеаіе Рагашеіег Ріеій (рис. 2.21) необходимо задать имя №те, 
тип Ѵаіие Іуре и сопроводительный текст РготрШц» іехі параметра. 


Сгеаіе Рагашеіег ПеІгі 


г а 1 НеИ — - — -- 

■-:- 
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ч * <; ‘ *Г «•> -— - - 

Ррмпрііпдіехі,' ' к (Укажите страны местонахождения клиентов ■' 

.--- 

.Уаіикіуре:' Г. Ѵ~ {Зігіпд .. . 


Оріюга у ..,,-.-- 
р \ АЯощтейкрІе ѵаіие* 


• 2е! сіеіаиіі ѵаіиеё , . 



Рис. 2.21. Диалоговое окно Сгеаіе Рагатеіег РіеШ 
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Рис. 2.22. Диалоговое окно 8е1 Оеіаиіі Ѵаіиез 
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Для задания значений параметра следует щелкнуть на кнопке 8е1 (ІеГаиН 
ѵаіиев. Открывается диалоговое окно 8еІ ВеГаиИ Уаіиез (рис. 2.22). 

В качестве значения по умолчанию можно задать произвольное значение 
либо набор значений из базы данных. Тип значения по умолчанию, выби¬ 
раемый из базы данных, должен соответствовать типу параметра. Если вы¬ 
бирается значение из базы данных, то в верхнем списке выбора диалогового 
окна 8еІ ВеГаиИ Ѵаіиез следует выбрать таблицу, в которой хранятся эти 
значения. В списке выбора Вгоѵѵ$е ЯеІ<і появляются поля таблицы, соответ¬ 
ствующие типу параметра. После выбора поля в левом списке появляется 
перечень значений, содержащихся в поле. Щелкнув на кнопке >, можно 
внести значение в правый список, тем самым задав значения параметра по 
умолчанию. 

При запуске отчета с параметрами появляется диалоговое окно Епіег 
Рагашеіег Ѵаіиея (рис. 2.23). В верхней части окна содержится список пара¬ 
метров, в нижней — список значений по умолчанию. 



Епіег Рагатеіег Ѵа(ие$ 


Рис. 2,23, Диалоговое окно Епіег Рагатеіег Ѵаіиез 


Использование параметров для выборки и в формулах будет рассмотрено 
далее. 
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2.6. Вставка в отчет кумулятивных полей 
(гиппіпд іоіаіз) 

Кумулятивное поле (гшшіп§ іоіаіз) "накапливает" значение какого-либо поля 
базы данных от строки к строке отчета. Так, если значение поля суммы 
в первой строке — 1, во второй — 3, в третьей — 2, то значением кумуля¬ 
тивного поля будет 1 в первой строке, 4 (1+3) во второй и 6 (1+3+2) 
в третьей. Имя поля піппіп§ іоіаіз в формулах начинается со знака "#", 
например, {#ту гиппіп» іоіаі}. 

Для создания кумулятивного поля необходимо в спискё полей диалогового 
окна Ріеісі Ехріогег переместить указатель на строку Киппіп§ Тоіаі РіеЫв и 
щелкнуть кнопкой мыши на кнопке создания объекта (табл. 2.1). Появляет¬ 
ся диалоговое окно Сгеаіе Киппіп« Тоіаі Ріеісі (рис. 2.24). 
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Рис. 2.24. Диалоговое окно Сгеаіе Виппіпд Тоіаі Ріеісі 


В правой верхней части диалогового окна расположено поле Киппіп§ Тоіаі 
№те, в которое следует внести имя кумулятивного поля. В левой части 
диалога Сгеаіе Киппіп§ Тоіаі Ріеісі находится список допустимых полей, 
из которых можно выбрать то, значение которого будет суммироваться (Ріеісі 
іо зшптагіге). Для выбора поля необходимо в левом списке переместить 
указатель на строку с именем поля или колонки, щелкнуть кнопкой мыши 
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на кнопке >, расположенной слева от поля Ріе1<1 іо зиттагае, и в раскры¬ 
вающемся списке выбрать тип агрегатной функции (Туре оГ зшпшагу). 

Секция Еѵаіиаіе позволяет определить порядок вычисления кумулятивного 
поля. Например, установка опции Рог еасЬ гесопі задает изменение значе¬ 
ния кумулятивного поля в каждой строке, при выборе опции Оп сЬагще оГ 
§гоир значение кумулятивного поля будет изменяться только при переходе 
к следующей группе. 

Секция Кезеі позволяет задать правила обнуления кумулятивного поля. Так, 
выбор опции Оп сЬап§е оГ §гоир означает, что для каждой новой группы ку¬ 
мулятивное поле будет вычисляться заново. 


2.7. Вставка в отчет 
полей 301 ехргеззіоп 

Вставка поля 80Т ехргеззіоп доступна только при работе с ЗОЬ/ООВС- 
источниками. Имя поля 8<ЗЬ ехргеззіоп начинается со знака процента: 

{%шу 8<ЗЬ ехргеззіоп}. 

Для создания поля 80Ь ехргеззіоп необходимо в списке полей диалогового 
окна Еіеігі Ехріогег переместить указатель на строку 8С>Т ехргеззіоп Гіеігіз и 
щелкнуть кнопкой мыши на кнопке создания объекта (табл. 2.1). Появляет¬ 
ся диалоговое окно 80Ь Ехргеззіоп №те (рис. 2.25), в котором надо задать 
имя поля 8СИ-. ехргеззіоп. 


301 Ехргеззіоп Лате 


І-ТеІС Ѵ: ; 

• у " 1 ОК | СапееІ ) 

Рис. 2.25. Диалоговое окно 5СИ. Ехргеззіоп Ыате 

После щелчка по кнопке ОК появляется диалоговое окно Еогтиіа 
\ѴогкзЬор — 80Ь Ехргеззіоп Егіііог (рис. 2.26). 

Интерфейс диалогового окна Ехргеззіоп Ейііог аналогичен интерфейсу 
Еогтиіа ѴѴогкзЬор — Еогтиіа Есіііог, который будет рассмотрен в главе 5. 
Диалоговое окно содержит четыре списка в порядке слева направо. 

1. Список формул. 

2. Список полей таблиц баз данных. 

3. Список функций. 

4. Список операторов. 
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Рис. 2.26. Диалоговое окно 

Рогтиіа ѴѴогкзНор - ЗОИ Ехргеззіоп ЕсШог 


Для внесения элемента любого из четырех списков в текст формулы необхо¬ 
димо переместить указатель на соответствующую строку и дважды щелкнуть 
по нему кнопкой мыши. 

В нижней части 8()Ь Ехргеззіоп показывается окно с текстом формулы. Все 
окна и панель инструментов диалога перемещаемые — можно расположить 
их так, как удобно. 

При обращении к реляционной базе данных Сгузіаі Вероііз 9 генерирует 
5<ЗЬ-выражение, в состав которого входит фрагмент, соответствующий полю 
8()Ь ехргеззіоп. Например, если значение поля 8 СІИ Ехргеззіоп есть ІІСА8Е 
('СизІотегѴСизІоіпег №те') (см. рис. 2.26), то при обращении к серверу ба¬ 
зы данных может быть сгенерировано выражение: 

ЗЕЬЕСТ 

Сизеотег.'СизСотег Нате', СизСотег.' ЬазЬ Уеаг’з Заіез' , СизСотег. 'СіСу' , 
{Гп ЦСАЗЕІСизЬотег .'СизСотег Иате')} 

РЕОМ 

Сизеотег.' СизЬотег' 

ОШЕК ВУ 

СизСотег.' СіСу' АЗС 

Помимо параметров, полей базы данных, специальных, текстовых полей 
и полей 8()Ь ехргеззіоп, отчет может включать формулы, которые будут рас¬ 
смотрены в последующих главах. 
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ІГогтаІ ЕсШог 


2.8. Вставка линий и рамок 

Отчету можно придать красивый вид, выделив данные линиями и рамками. 
Для рисования линий можно использовать два метода: 

1. Щелкнуть на кнопке "Нарисовать линию" в панели инструментов для 
вставки объектов в отчет (см. табл. 1.3). 

2. Выполнить команду меню Іпвегі | Ілпе. 

После этого курсор в окне отчета принимает вид карандаша. Для рисования 
линии надо передвинуть курсор на место начала линии и, нажав левую 
кнопку мыши, вести курсор к концу линии, затем отпустить кнопку. 

Для рисования рамки тоже можно использовать два метода. 

1. Щелкнуть на кнопке "Нарисовать прямоугольник" в панели инструмен¬ 
тов для вставки объектов в отчет (см. табл. 1.3). 

2. Выполнить команду меню Іпзегі | Вох. 

В окне отчета появляется курсор в виде карандаша. Для рисования рамки 
следует передвинуть курсор на место левого верхнего угла рамки и, нажав 
левую кнопку мыши, вести курсор к правому нижнему углу рамки, затем 
отпустить кнопку. 

Для форматирования линии или рамки следует переместить указатель на объ¬ 
ект и щелкнуть правой кнопкой мыши. В контекстном меню следует выбрать 
пункт Рогтаі Упе (форматирование линии) или Рогтаі Вох (форматирование 
рамки). Появляется диалоговое окно Рогтаі Еёііог (рис. 2.27). 


Рис. 2.27. Диалоговое окно для форматирования рамок и линий Рогтаі Есіііог 
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В диалоговом окне Рогтаі Егійог можно изменить толщину, цвет или стиль 
линии и рамки. Вкладка Коишіііщ (рис. 2.28) позволяет задать форму рам¬ 
ки — от прямоугольника до овала. 



Рис. 2.28. Вкладка Коипсііпд диалогового окна Рогтаі ЕсШог 

Рамки и линии, расположенные в секциях Неаёег и Рооіег, будут показаны 
на каждой странице. Рамки и линии, расположенные в секции Веіаіі, будут 
показаны на каждой записи. 

Упражнение 2.7 

1. Откройте отчет, созданный в упражнении 2.6. 

2. Нарисуйте цветную линию под заголовком. 

3. Нарисуйте цветную рамку вокруг наименования каждой группы. 

4. Нарисуйте штриховую линию в секции Ра§е Рооіег. 

5. Сохраните отчет. 

4 

2.9. Вставка рисунка и ОЬЕ-объекта 

Для создания красивых отчетов иногда целесообразно вставить в него ри¬ 
сунки. Например, это может быть логотип компании в заголовке. Для встав¬ 
ки рисунка необходимо: 

□ щелкнуть на кнопке "Вставка рисунка" в панели инструментов для вставки 
объектов в отчет (табл. 1.3) или выполнить команду меню Іпзегі | Рісйіге; 
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□ в списке выбора Тип файлов диалогового окна Открытие файла выбрать 
какой-либо формат, например .ВМР, ОІР, РСХ, ТІРР, ТОА; 

□ щелкнуть на Открыть (ОК) и расположить рисунок на отчете. 

Упражнение 2.8 

1. Откройте отчет, созданный в упражнении 2.7. 

2. Щелкните на кнопке Вставка рисунка. 

3. Выберите хСгете.Ьгпр из каталога Ргоецат Рі1е$\Сгу$іа1 [)есі$іоп$\Стіа1 
Вероігв 9\Затр1е$\Еп\ОаіаЪазе$. 

4. Расположите рисунок в секции Ра§е Неагіег. 

Вставка рисунка в отчет вышеописанным способом имеет один недоста¬ 
ток — рисунок невозможно редактировать, не выходя из отчета. Для редак¬ 
тирования такого рисунка необходимо изменить рисунок в другом приложе¬ 
нии, а затем в С гізтаі Керогй 9 удалить старый рисунок и вставить новый. 
Всех этих шагов можно избежать, используя технологию ОЬЕ (Офесг Ьіпк- 
іп§ апб ЕтЪескііпё). О ЕЕ позволяет вставлять в отчет данные или образы, 
которые берутся из других приложений, и модифицировать их внутри отче¬ 
та. Сгуыаі Керогк 9 является контейнером ОЬЕ и может возвращать объек¬ 
ты, которые созданы в других приложениях, если эти приложения поддер¬ 
живают ОЬЕ. 

Для вставки ОЬЕ-объекта следует выполнить команду меню Ькегі | ОЕЕ оіуесі. 
Появляется диалоговое окно Іпзег* ОЩесІ (рис. 2.29). 


Іпзегі ОЬіесІ 


С СгеаІеІІві^а'Ѵ' 


ШО 

/ ~6Г' І 


-Ріів; I *‘Вйтаріяѵаде. Сапсеі / 

-АЖуЙ 'Ц ’лЧД’'. . . . . . «*■«—> >■ ■ — ОХ . ' ' '• 

■■■(•'.--СйаЛё (грт Яе \Ргадіат РіІехЧСіухІаІ Оесі$іоп$\Сіуй . : : , 

} Г і-іпк. 

■ Г~ й ріауАаІсоп 






• ВйіА,- 


ІгеегШЬе еогіегАа о( іЬеЯе 35 ап оЬ|ес! іпіо ■ 
рАД) у<мфситеп(«'рІМуоишауасвѵаІеі(и«(пд 
ргпс'.-л- суНсЬ с-оаіегі.‘ . 


Рис. 2.29. Диалоговое окно Іпзеіі ОЬіесІ 


В диалоговом окне ІпзеП ОЩесі предлагается выбрать либо опцию Сгеаіе 
N6» (создать новый объект), либо Сгеаіе Ггот Рііе (выбрать существующий 
объект из файла). 
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При выборе опции Сгеаіе появится список Оіуесі Туре. Если выбрать 
какое-либо приложение, открывается соответствующее окно, в котором 
можно создать новый объект. 

Сгеаіе Ггот Рііе означает вставку в отчет существующего объекта. Например, 
для внесения в отчет книги Місгозой Ехеі как объекта, нужно щелкнуть на 
Рііе и выбрать имя файла из списка. 

Рисунок и ОЬЕ-объект выглядят в отчете одинаково. Однако при выделении 
рисунка будет доступен лишь минимальный набор опций форматирования, 
а объект, например рисунок, можно модифицировать с помощью приложе¬ 
ния, в котором объект был создан. Для редактирования объекта следует 
щелкнуть по нему дважды левой кнопкой мыши. 

Упражнение 2.9 

1. Откройте отчет, созданный в упражнении 2.7: 

2. Вставьте хСгете.Ьшр как объект. 

3. Отредактируйте рисунок, не выходя из Сгуйаі КерогГз 9. 

2.10. Использование хранилища 
объектов СгузіаІ Верозііогу 

Хранилище объектов СгузСаІ Керозііогу является новым инструментом, поя¬ 
вившимся в Сгузіаі КероЛз версии 9. Оно позволяет централизованно хра¬ 
нить и использовать объекты отчета. Хранилище объектов может быть соз¬ 
дано на локальном компьютере или на сервере, а объекты, единожды 
созданные и помещенные в хранилище, могут многократно использоваться 
одним или несколькими разработчиками для создания различных отчетов. 
Следовательно, хранилище объектов позволяет создавать единые корпора¬ 
тивные стандарты разработки отчетов. Кроме того, использование реляци¬ 
онных баз данных в качестве хранилища дает возможность эффективно ре¬ 
шать проблемы безопасности данных. Отметим, что хранилище объектов 
входит во все варианты поставки Сгузіаі Керопз 9, кроме варианта Зіапсіагсі. 

По умолчанию при инсталляции Сгузіаі Керогіз 9 создается хранилище объ¬ 
ектов с именем Сгузіаі Керозііогу. Это хранилище представляет собой базу 
данных М8 Ассезз и размещается в каталоге Рго§гаш Рі1ез\Соттоп РПез\ 
Сгузіаі Оесізіопз\2.0\Ъіп\К.ерозііогу.тс1Ь. Для создания нового хранилища 
следует создать сначала базу данных, а затем с помощью стандартных 
средств операционной системы новый СЮВС-источник данных. Вызов 
программы администрирования СЮВС в системе ХУіпсІоѵѵз 2000 выполняется 
выбором иконки Источники данных (СЮВС) окна Администрирование, кото¬ 
рое, в свою очередь, находится в окне контрольной панели (Сопітоі Рапеі). 
Затем на вкладке ІІзег ^8N диалогового окна СЮВС ИаСа 8оигсе 
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Асітішяітаіог (рис. 2.30) щелкнуть на кнопке А(М и с помощью мастера 
Сгеаіе №\ѵ Баіа Зоигсе задать свойства нового источника. 


(УООВС Оаіа Зоигсе АгітіпЫгаІоі 


ШегОЗМ |$у$1ет05№ | РіІеОЗЫ | Опѵеге] Тгасіпд] СоппесіГогі РооВпд | АБоіЛ ] 
У.сег Оа»а$о«се«: 


Мате 

Огіѵег 

Е 


РохРго Рііе$ 

РохРго РіІе$ - Ѵ/оіё 

Місккой РохРго Огіѵег (*.<ІЫ) 
МісгозоК РохРго ѴРР йпѵег [ х .с1Ьі) 


Ветбѵе ! 

М0І5 

М$ Ассе$$ 9? ОаіаЬа$е 

501 Зегѵег 

Місго$оЙ Ассе$$ Огіѵег ( х гпсіЬ) 


•у,- м ■■■■■ГГ, 

СопіідиеС., | 

М$ Ассезз ОаІаЬазе 

шашвяая 

МісгозоЙ Ассе$$ Огіѵеі р.гпсіЬ) 

50І_ 5егѵег 


Тез(1 

Мюго$оИ Ехсеі Огіѵег Г х!$) 


-.':.ѵЛ ; V: 

Т ехі Пег 

Місго$оН Тех* Огіѵег (*.М; * с$ѵ) 


: :■ ітС'у г •' 

Ѵ*$иаі РохРго РаіаЬеіе 

М*сго$оЙ Ѵі$иа1 РохРго Огіѵег 


• • • ■ .' -> •:" 

Ѵі$иаІ РохРго Т аЫе$ 

Місго$Ы* Ѵі$иаІ РохРго Огіѵег 

_ 

.у. ■./ ■ ‘и,- 


. ■ ■ у 

■>г 

ч ; , ■■■ 


Агі СЮВС Шег еіаіа зоигсе «|оге$ ЙсктаЬоп аЬоиі Но» (о сопоёсі (о ; 
'.«Не ЫісаЫ сіаіа ргоѵіі&г. А 1)$ес сіаіа яаигсев сф УІ8ІЬ1еіо.)гои:;-:5'-;'.’і:. 
аі*і сапоп!уЬе іеесіопйіесшепітасЬіпе. ...•■•;' у; 


ИНМ 

• Сапсе).. 


'у’НеІр'' 

К 



Рис. 2-30. Диалоговое окно СЮВС Оаіа Зоигсе Агітіпізігаіог 


Следующим шагом является описание хранилища в файле огМар.іпі. Этот файл 
по умолчанию находится в каталоге Рго§гат Рі1е$\Соттоп Рі1е8\Сгу5іа1 ІЗесіхіоп8\ 
2.0\Ьіп. В файл огМар.іпі должна быть добавлена строка в формате 

<Наименование хранилища>=<наименование СШВС-источника>. 

В имени хранилища нельзя использовать символы #, ", {, }, ; и /. Например, 
если создается новое хранилище №\ѵ Керозііогу, которое будет использовать 
ООВС-источник данных МуСгу5іа1К.еро8Йогу, содержимое файла огМар.іпі 
должно быть следующим: 

п"і# ЗупСах: 

# 

# сгерозіСоху пате>=<геа1 Дара зоигсе пате> 

# 

# Ріеазе поре (Шар сгерозіСоху пате> саппоР сопраіп рЬезе зресіаі 
сЬагасРегз ~ # ” { } ; / 

# Апу епсху «ДіаР сопраіпз зисЬ ѵй.11 Ъе ідпогей. 

# Аізо, ЬМз Еііе із заѵеД ѵ/іРЬ ОТР8 епсойіпд. ТЬіз аііоадз <герозіСогу 
пате> Со Ье оЕ ипісойе сЬагасЕегз. 

# 

Ием КерозіЕогу=МуСгузі;а1Керозіі;огу 
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Сгузіаі К.ероп$ 9 позволяет использовать только одно хранилище. Перекон¬ 
фигурация файла огМар.іпі приводит к невозможности использования ста¬ 
рого хранилища. Если во время создания нового источника данных и кон¬ 
фигурации файла огМар.іпі Сгузіаі Керопз 9 был открыт, его следует закрыть 
и открыть вновь. Только после этого новое хранилище можно использовать. 

Хранилище объектов может содержать несколько вложенных папок. Для 
создания новой папки следует перейти в диалоговое окно КеровКогу 
Ехріогег (рис. 1.5), переместить указатель на строку древовидного списка, 
щелкнуть правой кнопкой мыши и выбрать в контекстном меню пункт №\ѵ 
Роігіег. В появившейся строке списка следует внести имя новой папки. 

Каждая папка может содержать объекты четырех типов: 

1. Текстовые объекты; 

2. Рисунки. 

3. Специальные функции (Си$1от Гипсііош). 

4. Запросы (сотташЗз или ^иепе$). 

Объекты перечисленных типов могут быть добавлены в хранилище из отчета 
или извлечены из хранилища и помещены в отчет. 

Для создания специальных функций предназначена среда разработки фор¬ 
мул Рогтиіа \Ѵогк$Ьор, откуда они помещаются непосредственно в храни¬ 
лище (см. главу 5). Запросы (соттапбз) могут быть созданы в диалоговом 
окне Ба(аЬа$е ЕхреіЧ и также помещены в хранилище. Для размещения за¬ 
проса в хранилище необходимо при его создании в диалоговом окне А<М 
Соттапй То Керогі включить опцию А<М Іо Керо$ііогу. 

Текстовый объект или рисунок может быть помещен в хранилище одним из 
двух способов: 

□ переместить текстовый объект или рисунок из рабочего окна отчета 
в диалоговое окно Керозііогу Ехріогег; 

□ щелкнуть на текстовом объекте или рисунке правой кнопкой мыши 
и выбрать пункт меню А<М іо Керозііогу. 

В возникающем при этом диалоговом окне АФ1 Нет (рис. 2.31) следует ука¬ 
зать наименование объекта — поле №те, автора — поле АиіЬог и ввести 
описание в поле Везсгірііоп. В нижней части окна содержится древовидный 
список папок хранилища Ьосаііоп. В нем необходимо выбрать папку, в ко¬ 
торую будет помещен объект, после чего щелкнуть на кнопке ОК. 

Для внесения текстового объекта или рисунка из хранилища в отчет доста¬ 
точно просто переместить его методом Ога§&Огор из диалогового окна 
Керозііогу Ехріогег в соответствующую секцию отчета. 

Для внесения в отчет специальных функций следует воспользоваться диа¬ 
логовым окном Рогтиіа Ехрегі, которое будет описано в главе 5. Запросы, 
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размещенные в хранилище, являются источниками данных и могут быть 
включены в отчет наряду с прочими источниками данных с помощью диа¬ 
логового окна ВаіаЬаве Ехрегі. 



Рис. 2.31. Диалоговое окно АсШ Нет 


Перенесенные из хранилища в отчет рисунки и текстовые объекты нельзя 
редактировать, однако их можно обновить непосредственно в хранилище. 
При внесении в хранилище нового текстового объекта или рисунка на место 
старого возникает диалоговое окно А<і<1 ог Ерёаіе Оіуесі (рис. 2.32). 



Рис, 2.32, Диалоговое окно АсІсІ ог Ырсіаіе ОЬіесІ 


Если выбрана опция ІІрйаіе Йіе героН оіуесі іп Йіе геровііогу, то новый объ¬ 
ект будет записан на месте старого. 
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Выборка, сортировка 
и группирование записей 

3.1. Выборка записей 

Обычно в отчете отображается только часть информации, хранящейся в базе 
данных. В главе 2 было рассмотрено окно Кесогчі Зеіесііоп мастера Зіапйаічі 
Керогі Сгеаііоп \Ѵігагй, позволяющее задать условия отбора записей при 
создании отчета. Рассмотрим, как можно ввести в существующий отчет до¬ 
полнительные условия отбора, 

Сгузіаі КероПз 9 допускает две возможности задания условий отбора записей. 

1. Задание условий с помощью диалогового окна Зеіесі Ехрегі. 

2. Задание условий путем определения формул (Зеіесііоп Роптшіаз). Эта 
возможность будет рассмотрена в главе 5. 

Диалоговое окно Зеіесі Ехрегі (рис. 3.1) можно вызвать либо командой ме¬ 
ню Керог* | Зеіесі Ехрегі, либо щелкнув на кнопке выбора данных в панели 
инструментов для анализа (табл. 1.4). 



Рио. 3.1. Диалоговое окно Зеіесі Ехреіі 


Если в отчете не были заданы условия отбора, то сначата появляется диа¬ 
логовое окно СЬоозе Ріеій (рис. 3.2) для выбора поля отчета или поля базы 
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данных, к которому будет применено условие отбора. Кнопка Вптве в этом 
окне позволяет просмотреть первые 100 различных значений поля. 



I СНоохе Ріеісі 


О 


|і Веров РіеИ$ 


аз Сийотег 1_а$1 Уеаг'х 5аІе$ 
оз СизІоліеі.Сйу 
пэ Си$Іот#.СопІасІ ТЦІе 
оэ Сийотеі.СопІасІ Ріг$1 Мате 
оэ Си$Іот«.Соп*асІ І.ай Иате 
X ПероФАге&Зит о( Си5*.отег.1а$1 Уеаг'г ЗаГ 
X Сгоир #1: СихІотег.Сйу • А:5ит о* Си^.отег 
і СЛРгодсат РіІе$\Сгу®Іаі 0есІ2іопг\С(у$Іа1 Перогі 
і-1 Сироте* 

• оз СшІотегЮ 

оз Сихіотег СгесйЬ Ю •_ 




Рис. 3 . 2 . Диалоговое окно СНоозе РіеІсІ 


Каждому логическому условию выборки соответствует одна вкладка в диа¬ 
логовом окне 8е1есІ ЕхреП. Все условия объединяются логическим "и". На¬ 
пример, если установлено два условия: 

{СизСотег.ЬазС Уеаг'з Заіез} із дгеаЬег СЬеп $10000 

И 

{СизСотег .СоипСху} із едиаі Со Ргапсе 

то в отчет будет внесена информация только о клиентах, проживающих во 
Франции и одновременно сделавших заказы более чем на $10000. 

Для удаления условия нужно перейти на соответствующую вкладку и щелк¬ 
нуть на кнопке Пеіеіе Для создания нового условия следует щелкнуть на 
кнопке №\ѵ. Появляется диалоговое окно СЬоове Ріеіф в котором следует 
выбрать поле и щелкнуть на кнопке ОК. Автоматически создается новая 
вкладка в диалоговом окне 8е1есі Ехреіі (рис. 3.3). 
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Каждая вкладка диалогового окна в левой части содержит список выбора, 
предназначенный для задания логического оператора. Содержимое списка 
зависит от типа поля (числовое, строковое или дата). Служебное слово поі 
используется для отрицания условия, например, условие із поі е^иіа1 вклю¬ 
чит в отчет строки, значения поля в которых не равно заданному. 

Допускается использование следующих операторов. 

□ е^иаI Іо — равенство. Применимо для поля любого типа. 

□ опе о! — равенство любому значению из заданного списка. Применимо 
для поля любого типа. В случае выбора оператора опе оГ в правой части 
диалогового окна 8е1есі Ехрегі появляется раскрывающийся список, со¬ 
держащий значения поля и под ним список значений, на основе кото¬ 
рого будет создано правило отбора. Для внесения значения поля в ниж¬ 
ний список достаточно раскрыть верхний список, переместить указатель 
на строку с именем поля и щелкнуть по нему кнопкой мыши. 

□ §геаІег (Іевв) іЬеп ог е^иа^ Іо — больше (меньше) или равно. Применимо 
для поля любого типа. 

□ Ьеілѵееп — задает верхнюю и нижнюю границу значений поля. Примени¬ 
мо для поля любого типа. 

□ яіагів \ѵііЬ — выбирает текстовые поля, начинающиеся с заданного сим¬ 
вола. 

□ Ііке — выбор текстового поля по маске. Допускаются маски: 

• * — последовательность си мволов, 

• ? — один символ. 

□ Рогтиіа — установка выборки по формуле (см. главу 5). 

□ іп іЬе регіогі — применимо для поля типа дата и дата-время. Можно ис¬ 
пользовать формулы периода (си. главу 5). 

При попытке просмотра отчета после создания нового условия выборки вы¬ 
водится диалоговое окно СЬагще Іп Кесопі Зеіесііоп Рогіпиіа Пеіесіеіі 
(рис. 3.4), в котором предлагается использовать в отчете сохраненные дан¬ 
ные или обновить их из источника данных щелчком на кнопке КеігевЬ Паіа. 


СЬапде Іп Весоігі Зеіесііоп Рогтиіа Оеіесіесі 


Ѳ 


ийіаѵей сіаіа (гот: 15.04.03 .22:00 ? 

Ве(ге$И &э(а 


■■ У «е Іэѵесі Ваіа 


Рис. 3.4. Диалоговое окно 

СЬапде Іп Ресогсі Зеіесііоп Рогтиіа Оеіесіесі 
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Используя возможность работы с сохраненными данными, можно, меняя 
правила отбора, последовательно включать в отчет все меньший и меньший 
набор данных. Однако в любое время можно принудительно обновить дан¬ 
ные, выполнив команду меню Керогі | КеГгевЬ Керогі Баіа или нажав кла¬ 
вишу <Р5>. 

По умолчанию условие выборки учитывает регистр. Например, если по ус¬ 
ловию Ке§іоп і§ ечиіаі іо СА, выбираются записи с са, а не са, сА, са. Если 
в качестве источника данных был выбран СЮВС, то можно настроить оп¬ 
цию чувствительность к регистру — БаіаЪазе 8егѵег і§ Сазе-Іпкепзіііѵе, вы¬ 
полнив команду меню Рііе | Орііопз на вкладке ОаіаЬаке диалогового окна 
Орііопз. В этом случае по условию Ке§іоп і$ е<іиіаІ іо СА будут выбираться 
все записи, содержащие и са, и са, и са, и са. 

Упражнение 3.1 

Откройте отчет, созданный в упражнении 2.6. 

1. С помощью диалогового окна 8е1есі Ехрегі создайте дополнительное ус¬ 
ловие выборки для поля Ке§іоп так, чтобы в отчет включались записи со 
значениями СА, ЫУ и РЬ. 

2. Просмотрите отчет. Убедитесь, что поле Кещоп содержит только значе¬ 
ния СА, ЫѴ или РЬ. Для этого внесите поле Ке^іоп в секцию Оеіаіі. 

3. Сохраните отчет. 

Примечание ^ 

Каталог Ргодгат РіІез/СгузіаІ Оесізіопз/СгузіаІ Керогіз 9/ЗатрІез/Еп/Рерогіз/ 
Реаіиге Ехатріез содержит ряд примеров, иллюстрирующих различные 
приемы построения отчетов. В частности, файлы ГСесогс) Зеіесііопі.грі и 
Ресогсі 5еІесІіоп2.гр{ содержат отчеты, которые показывают возможность уста¬ 
новки условий выборки с помощью окна Зеіесі Ехрегі. 


3.2. Группирование записей 

По умолчанию записи в отчете располагаются в том порядке, в котором они 
располагаются в базе данных для настольных баз данных или в результи¬ 
рующем наборе данных для реляционных СУБД. Часто требуется сгруппи¬ 
ровать записи, например, покупателей из одного города расположить вме¬ 
сте. Такая операция называется группированием записей — в одну группу 
включаются записи с одинаковым значением определенного поля. Сгруппи¬ 
ровав записи, можно суммировать данные в каждой группе, например, под¬ 
считать общую сумму продаж или количество покупателей в каждом городе. 
В главе 2 было показано, как с помощью окна Сгоирігщ мастера Зіашіагй 
Керогі Сгеаііоп \Ѵігагй добавить группу в новый отчет. 
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Вставить группу в уже существующий отчет можно двумя способами: 

1. С помощью диалогового окна Сгоир Ехрегі. 

2. С помощью диалогового окна Іпяегі Сгоир. 

Диалоговое окно Сгоир ЕхреП (рис. 3.5) можно вызвать, выполнив команду 
меню КероН | Сгоир Ехрегі или щелкнув на соответствующей кнопке в па¬ 
нели инструментов для анализа (табл. 1.4). 


КЗ Сгоир Ехреіі 


АѵайаЫе РіеМ*: ■ 




та АсІЛе$&1 
ош Аскке$$2 
та Сі^і* 
та Ведіоп 

оз Ро$*аі Сосіе 
та Е-таіі 
та ѴеЬ ЗІІе 
та РНопе 
та Рах 


ж 



: . ' : 

Ж 

• : » 




■ ' 


ч 


« 




■ І-Чѵ..-?.'-'-." -■ 

ч: 


-Сі^огг^^Ведіогі-А. 
2 Си$(отеі.Сі(у -А 


Вгоілізе ОаЬэ Гіпсі Ріеі<1... ' ‘ Орйоп^.. . 


Д ; .• - • • ѵ- ѵ . . • • ; 


:0К - ■ 


V .'Ж : ?'■' 

; СапсеІ 


Неір 


Рис. 3.5. Диалоговое окно Сгоир Ехрегі 


Левый список окна — АѵаіІаЫе РіеЫз содержит поля отчета и поля таблиц, 
на основе которых могут быть созданы группы. Правый список Сгоир Ьу 
содержит группы отчета. Для создания в отчете новой группы необходимо 
в левом списке переместить указатель на строку с наименованием поля, по 
которому будет проведено группирование, и щелкнуть кнопкой мыши на 
кнопке >. Над списком Сгоир Ьу расположены кнопки, позволяющие изме¬ 
нять порядок группировки. 

Для вызова диалогового окна Ішегі Сгоир (рис. 3.6) следует выполнить ко¬ 
манду меню Іпзегі: | Сгоир. 

Для вставки группы необходимо в верхнем списке вкладки Соішпоп диало¬ 
гового окна Іпзегі: Сгоир выбрать поле для группирования и порядок, 
в котором группы должны показываться. Например, для рассматриваемого 
отчета можно выбрать группирование по полю Ке§іоп. Можно сгруппиро¬ 
вать информацию по полям отчета или даже по полям, которые не входят 
в отчет. 

Порядок сортировки групп можно установить в нижнем списке выбора. 
Группы могут располагаться в порядке возрастания — іп а$сешііп§ огйег 
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(от А до 2 и от 1 до 9) и в порядке убывания — іп дезсешШщ огдег (от 2 до А 
и от 9 до 1). При выборе іп огі§іпа1 оггіег сортировка групп не производится. 
Наиболее интересна сортировка іп зресіПегі опіег. Она позволяет установить 
группирование по признаку, который не хранится в базе данных. При выбо¬ 
ре сортировки іп зресШей оггіег в диалоговом окне Іпзегі Сгоир появляется 
вкладка 8ресШеё Оггіег (рис. 3.7). 



Іпзегі Сгоир 


[|іп азсепсіігід опіег. 


\уЬё;тйіе іероЛ і$ ргаКёАІИе іесогск «Л Ье ?оЛегі агкі 
. дгоиреЬ Ьу: ;; ; 


Пю зесііоп »ІІІ Ье ргігіІеЬ.ои апу сЬапде Ы: 
Ведіоп . 


Отмена 


Рис. 3.6. Диалоговое окно Іпзеіі Сгоир 



Рис. 3.7. Вкладка Зресіііесі Огсіег диалогового окна Іпзегі Сгоир 


Например, необходимо выделить группы англоговорящих или испаногово¬ 
рящих стран. Для этого сначала нужно описать эти группы. Если щелкнуть 
на кнопке №>у, появляется диалог БеГіпе №те<1 бгоир (рис. 3.8). 

В этом диалоге можно задать логическое условие, описывающее группу. 
На рис. 3.8 испаноговорящие страны — Аргентина, Мексика и Испания. 

Вкладка Орііопз диалогового окна Іпзегі Сгоир служит для настройки 
свойств групп. 
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І ОеКпе Ыатегі Сгоир 


йгоирЫйте:'*' | И спаногоеорящие 
С^отег.Соилі^ | <Неѵ^> | 

—ЗГ 


11$ опе 


Ветоуе-: 


Мехісо 

Агдепііпа 


Г*1 


“3 


ОК I ■ СапсеІ 


Нф 


Вго«5вРа(а.. 


Рис. 3.8. Диалоговое окно ОеГіпе Ыатесі Сгоир 


Сотгаоп Орііопз ] *ѵ . - > .. 


: ’-’^'Й^м^біоцр-КІагоеіЯаЦ • 

1 ■ 

СИоо$еПотіхі$(іпдЯеН 


03 Си$*отег.Си$*отегМате 

“3 ' 

ГІ56 а Роптііа аз.Сгоир Ыате 

■ ■ ч : ’ ‘ ’ V 

Г” КеерБгоирТодеіЬеі . 



Г* НереаГбгоир'Неасіеі Оп ЁасН Раде : 



Рис. 3.9. Вкладка Орііопз диалогового окна Іпзегі Сгоир 

Установка опции Кеер §гоир Іо§еДіег предотвращает разрыв группы на раз¬ 
ные страницы. 

Использование опции Кереа* Сгоир Неаёег Оп ЕасЬ Ра§е позволяет повто¬ 
рить заголовок группы на каждой странице, если группа располагается на 
разных страницах. 

При создании каждой группы в отчет добавляются новые секции — Сгоир 
Неагіег и Сгоир Рооіег. По умолчанию в секцию Сгоир Неа<1ег добавляется 
заголовок группы — значение поля, по которому производится группиро¬ 
вание. Например, если производится группирование по городу, в качестве 
названия группы берется название города. Если группирование выполняется 
по числовому полю или дате, в качестве названия группы берется конверти¬ 
рованное в строку значение поля. Иногда не вполне удобно брать в качестве 
названия группы значение поля. Так, если группирование производится 
по номеру клиента, логичнее было бы в качестве названия взять имя клиен¬ 
та, а не его номер. Опция Сикіошіге Сгоир ^те Ріеігі (рис. 3.9) позволяет 
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в качестве названия группы указать значение любого поля или формулы, 
например: 

ТоТехе {{СизСотег .СизСотегГО) ) + " : " + {СизСотег.СизеотегИате}) 

Новая группа автоматически становится внутренней. Если в отчете уже су¬ 
ществовала группа, то необходимо следить за правильностью логики груп¬ 
пирования. В рассматриваемом нами примере в одной стране может быть 
несколько городов, а не наоборот. Изменить порядок групп несложно. Для 
этого, находясь на вкладке Бе8І§п, нужно переместить методом Вгая&ІЗгор 
заголовки секций ерупп (рис. 3.10). 


!'. Сгоир НеагіеіЩ. .. - ■ 

| : Си5Іотег.СІ(у - А - СДч 

&гоир#1 Цате 

:! Сгоио Неаёеі #2: <ж 

Сгоир и 2 Цате 


Ойаік _ ч . ; : 

Редід рііу * 

Іі Сгоир Рооіеі #2: • ' . 


і СюирРосЛегМ- ■ 

; Си$(отег.СІІу - А ' ^ 

Сгоир #1 Нате ] 


Верой Рооіеі ' . х> 

р гагиі Тоіаі: ’ 


Рис. 3.10. Изменение порядка группирования 


Если группирование производится по полю типа дата, на вкладке Соттоп 
диалога Іпзегі Сгоир появляется список выбора, позволяющий задать опции 
группировки (рис. 3.11). Например, в одну группу могут быть объединены 
записи по значению поля типа дата за один день, одну неделю, месяц, квар¬ 
тал, год и т. д. 


Іп$егІ Сгоир 


Ш 


Соттоп | ррііопз ) 


: Ѵ/Ьеп (Не гёроЛ к рііпіесі, .(Не іесоі* «Я Ье «огІеУ эп'сГ. 
дгоиреЦ Ьу - " - 


5Ьір Оаіе 

2І 

| іл а$сепс!іпд огсіег. 

3 

Т Не аеЫіоп ииЗІ Ье 


(ог еасН сіау. 

V- 

кн еасН меек. 

еасН іѵѵо ѵѵеек$. 
іо( еасН НаК топІИ. 
еасН топіН. 
еасН яиагіег. 

(ог еасН НаІ? уеаг. 



Рис. 3.11. Группирование по полю типа дата 
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Упражнение 3.2 

1. Откройте отчет, созданный в упражнении 2.6. 

2. В диалоговом окне Зеіесі Ехрегі удалите все условия выборки. 

3. Сгруппируйте отчет по полю Соипігу и установите сортировку іп зресШед 
оггіег. 

4. Создайте группы англоязычных и испаноязычных стран, как описано 
ранее. 

5. Выделите заголовок группы Соипігу фоном или цветом. 

6. Сделайте группу по странам внешней по отношению к группе по горо¬ 
дам. 

7. Сохраните отчет. 

Сгузіаі Керогіз 9 позволяет производить группирование на основе данных, 
образующих иерархическую рекурсию. Иерархическая рекурсия — это 
структура данных, в которой таблица ссылается на саму себя. Пример такой 
таблицы в обозначениях стандарта ГОЕР1Х показан на рис. 3.12. Например, 
в таблице Ешріоуее хранится информация о сотрудниках фирмы. Поле 
Етріоуее ГО содержит номер сотрудника, а поле Керогіз То — номер руко¬ 
водителя сотрудника, при этом информация о нем хранится в той же табли¬ 
це. Поле Керогіз То может принимать значение Г4ШЛ — это показывает, 
что у сотрудника может и не быть руководителя. 


Етріоуее 


Етріоуее 10 


Зирегѵізог I й 
1_азі ІМате 
Рігзі Ыате 
РозШоп 
ВігІІп Оаіе 
Ніге Оаіе 
Ноте Рйопе 
Ехіепзіоп 
РЙОІО 
ІМоІез 

Верогіз То (РК) 
Заіагу 



і 




Рис. 3.12. Пример таблицы с иерархической рекурсией 
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Сгузіаі КероПз 9 позволяет создавать древовидный отчет, раскрывающий 
структуру подчинения сотрудников организации. Для этого необходимо соз¬ 
дать группу по первичному ключу таблицы Етріоуее ГО, затем выполнить 
команду меню Керогі | НіегагсЬісаІ Сгоиріп§ Орііош. В открывшемся диа¬ 
логовом окне НіегагсЬісаІ Орііоп» (рис. 3.13) следует включить опцию 5огІ 
Баіа НіегагсЬісаІІу и указать родительское поле группы Рагепі ГО Ріеіё, 
в примере это — Керогі» То. 


НіегаісНісаІ Орііопз 


АѵаЯаЫеЦгофК- 


Етріоѵее. Егпріоѵее 10 


Щ 


НіегагсЬісаІІу : 

. ^п$1апсеі0 Гіей • 

- • ■ • 

• Рагепі Ю РіеІгі . : 

. | аз Ріерогіз То ~~ 


И 


/бгоир 'ІпУепі • .. ^ ~~ . ст -і 




П 0К: ; Ц ‘Сапой 


;Не1р 


Рис. 3.13. Диалоговое окно НіегагсЬісаІ Орііопз 


В поле Сгоир Іпгіепі указывается смещение вправо группы нижнего уровня 
отчета в сантиметрах. Уровень вложений не ограничен. Пример отчета с ие¬ 
рархической группировкой показан на рис. 3.14. 



Рис. 3.14. Пример отчета с иерархической группировкой 
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3.3. Сортировка записей 

После группировки информации в отчете, внутри групп она располагается 
в произвольном порядке. Для упорядочения записей необходимо установить 
порядок их сортировки, например по алфавиту. 

Для установки порядка сортировки необходимо выполнить команду меню 
Керогі | Кесоггі 8ог* Ехрегі или щелкнуть на соответствующей кнопке пане¬ 
ли инструментов для анализа (табл. 1.4). Появляется диалоговое окно Кесогё 
8ог1 Огёег (рис. 3.15). 


1 ВесогсІ 5оіІ Оггіег 
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. —— 

ѵ Луг- .7 ' 1 •'.ѵС>л--. ;*Ѵ.••••••. 
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Сапсеі 
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Рис. 3.15. Диалоговое окно ВесогсІ 5огІ Огсіег 


В диалоговом окне Кесогй 8огі Огйег по умолчанию устанавливается сорти¬ 
ровка по тем полям, по которым установлено группирование. Для задания 
дополнительной сортировки внутри групп необходимо переместить указа¬ 
тель на строку с наименованием поля в левом иерархическом списке 
и щелкнуть по кнопке >. Поле перемещается в правый список. Опции 
АзсешНщ; и Бе8сепёш§ определяют порядок сортировки по возрастанию 
и убыванию соответственно. 


Упражнение 3.3 

1. Откройте отчет, созданный в упражнении 3.1. 

2. Установите сортировку информации по полю Сизіошег Ште в порядке 
возрастания. 

3. Сохраните отчет. 


Зок. 1021 
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3.4. Вставка агрегатных полей (Зиттагу) 

После группировки информации в отчете можно добавить в него некоторую 
суммирующую информацию, например, количество компаний в каждом городе. 

Для отображения суммирующей информации служат агрегатные (Зиттагу) 
поля, такие как сумма, максимальное, минимальное или среднее значение. 
По умолчанию они размещаются в секции отчета Сгоир Рооіег. 

Для вставки поля Зиттагу следует переместить указатель на поле в секции 
ОеіаіІ и щелкнуть по нему правой кнопкой мыши. В контекстном меню 
следует выполнить команду Іпзегі | Зиттагу. Появляется диалоговое окно 
Іпзегі Зиттагу (рис. 3.16). 


Іпзеіі Зиттагу 


Отоо$е 8» (іеМ Іо іи'тгйа'ій:. 
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Рис. 3.16. Диалоговое окно Іпвеіі Зиттагу 


В раскрывающемся списке СЬоозе іЬе Пеій Іо зиттагіге в верхней части 
диалогового окна Іпзегі Зиттагу следует выбрать поле, по которому будет 
производиться вычисление, а в списке Саісиіаіе Шз зиттагу — тип агрегат¬ 
ной функции. 

Раскрывающийся список Зиттагу Іосаііоп служит для выбора группы, в рам¬ 
ках которой будет производиться вычисление. Результат вычисления — агре¬ 
гатное поле — будет помещен в секцию Сгоир Рооіег выбранной группы. Если 
выбрать значение Сгаші Тоіаі (Керогі Рооіег), то вычисление будет произво¬ 
диться по всему отчету, а результат будет помещен в секцию Керогі Рооіег. 
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Если группы, по которой необходимо произвести вычисление, не существу¬ 
ет, можно щелкнуть на кнопке Іпзегі Сгоир. Возникает диалоговое окно 
Іп$ег1 Сгоир (рис. 3.6), в котором можно создать новую группу. 

Опция 8Ьо\ѵ а$ а регсеп!а§е оГ в нижней части диалогового окна Іпкегі 
Зшшпагу позволяет показать вычисленное значение как процент от другого 
агрегатного поля, которое указывается в нижнем списке выбора. Например, 
если в списке Зшптагу Іосайоп указано значение Сгоир #1: Сиаіотег.СіІу-А, 
а в нижнем списке — Сгапё Тоіаі: 8шп оГ Ьакі Ѵеаг’8 8а1ек (рис. 3.16), то 
в отчете будет показываться не абсолютное значение продаж в каждом горо¬ 
де, а процентное отношение к общему количеству продаж. 

Для вставки агрегатного поля в отчет следует щелкнуть на кнопке ОК. 

Упражнение 3.4 

1. Откройте отчет, созданный в упражнении 3.3. 

2. Подсчитайте количество клиентов в каждом городе, для этого вставьте 

8иЫоіа1 (соипі) для поля Сияіотег Иате. 

3. Вставьте текстовый объект в качестве подписи. 

4. Сохраните отчет. 

Упражнение 3.5 

1. Откройте отчет, созданный в упражнении 3.4. 

2. Подсчитайте общее количество клиентов в отчете, для этого вставьте 

Сгапё Тоіаі (соипі) для поля Сизіотег N3016. 

3. Вставьте текстовый объект в качестве подписи. 

4. Сделайте так, чтобы обе подписи выделялись шрифтом или цветом. 

5. Сохраните отчет. 

3.5. Порядок сортировки группы 
по суммирующим значениям. 

Сортировка ТорЫ 

В разд. 3.2 было показано, как группировать записи и сортировать группы 
в порядке убывания или возрастания заголовков групп. Однако группы могут 
быть отсортированы и по результату вычислений суммирующих значений. 
Например, может быть установлена такая группировка, когда города с наи¬ 
большим количеством клиентов будут расположены в верхней части отчета. 
Для установки такой сортировки следует выбрать пункт Сгоир 8ог1 Ехрегі из 
меню Керогі Появится диалог Сгоир 8ог1 Ехрегі с вкладкой для каждого аг¬ 
регатного поля отчета (рис. 3.17). Заголовок каждой вкладки — это имя поля, 
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по которому производилось группирование. Например, если в отчете произ¬ 
водится подсчет количества клиентов в каждой стране и в каждом городе, 
группы будут показываться на вкладках Сикіотег.СіІу и СихІотег.Сошійгу. 



3 Вюир 5ог( Ехрегі 




СівІипегСоипІі}) Сойота.СКу 
Гоі 1М$ діоир 5оЛ 


ЬаіеДргГ; | Соипі о( Сийотег.СшІотег Иате 


[7 ІпсІисІе біЬёв.жіНЙіе паппе: 


Ѵѵ'НеіеЫи: 


Г'ТпсІисІеііе* 


Рис. 3.17. Диалоговое окно Сгоир Зогі Ехрегі 



Опции сортировки групп, которые можно выбрать в раскрывающемся спи¬ 
ске Рог 1ЬІ8 §гоир во гі диалогового окна Сгоир 8ог( Ехрегі приведены 
в табл. 3.1. 

Таблица 3.1. Опции сортировки групп 


Опция сортировки Описание опции 

Зогі аІІ Будут отсортированы и напечатаны все группы 

Тор N Будут отсортированы и напечатаны группы с наибольшим 

значением агрегатного поля, например города, где количе¬ 
ство клиентов больше, чем в остальных. В поле ѴѴЬеге N із 
нужно указать, сколько групп — N — нужно включать в отчет 

ВоНоп N Будут отсортированы и напечатаны группы с наименьшим 

значением агрегатного поля. В поле \Міеге N із нужно ука¬ 
зать, сколько групп — N — нужно включать в отчет 

Тор Регсепіаде Будут отсортированы и напечатаны группы со значением 

агрегатного поля, большим указанного количества в процен¬ 
тах от общего количества. Например города, где количество 
клиентов больше, чем 20 % от общего количества клиентов в 
отчете. В поле ѴѴНеге Регсепіаде із нужно указать величину 
процентов 
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Таблица 3.1 (окончание) 

Опция сортировки 

Описание опции 

Воііоп Регсепіаде 

Будут отсортированы и напечатаны группы со значением 
агрегатного поля, меньшим указанного количества в процен¬ 
тах от общего количества. В поле ѴѴНеге Регсепіаде із нуж¬ 
но указать величину процентов 


Для сортировки всех групп нужно выбрать 8огІ аіі и затем суммирующее 
поле, по которому производится сортировка. Например, если одновременно 
подсчитывается количество клиентов и общая сумма заказов за прошлый 
год, в списке будут присутствовать значения Соипі оГ Си$1отег.СиЫотег 
Ште и 8ит оГ ЬаЫ Уеаг’з 8аІе$. Если выбрать Соипі оГ Сизіотег.Сизіошег 
Nаше и а$сеп<ііп§, в отчете будут представлены сначала города с наимень¬ 
шим, затем с наибольшим количеством клиентов, т. е. упорядоченные по 
возрастанию. Если выбрать 8шп оГ 8иш оГ Ьа$і Уеаг’8 8а1ез и а$сешііп§, 
в отчете будут представлены сначала города с наименьшими, затем с наи¬ 
большими суммами продаж. 

Опция Тор N предоставляет мощные средства сортировки. Если нужно вы¬ 
нести наверх несколько групп с наибольшим значением суммирующего по¬ 
ля, можно использовать опцию Тор N и указать Ы, например, 3, 4, 5. 

Опция Іпсіиёе ООіегз, тѵіяЬ Яіе паше указывает, будут ли включены в отчет 
записи, не относящиеся к отсортированным группам. Если опция включена, 
остальные записи будут объединены и включены в группу "прочие”. Заголо¬ 
вок для группы "прочие" можно изменить, по умолчанию он — Огііег. 

Упражнение 3.6 

1. Откройте отчет, созданный в упражнении 3.5. 

2. Упорядочьте группы по городам так, чтобы три города с наибольшим ко¬ 
личеством клиентов были представлены в верхней части группы по стра¬ 
нам, а остальные города — в группе "прочие". 

3. Сохраните отчет. 








Глава 4 



Диаграммы 

и географические карты 

4.1. Вставка диаграммы 

Очевидно, что представление информации в графическом виде гораздо на¬ 
глядней, чем просто в виде таблиц. Сгузіаі Кероііх 9 позволяет создавать 
диаграммы с использованием специального инструмента — СЬагі ехрегі. 
Опытные пользователи могут улучшить изображение диаграммы с помощью 
более изощренного и мощного редактора. Рассмотрим сначала создание 
диаграммы с помощью СЬагі ехрегі 

Для вставки диаграммы в отчет необходимо выполнить команду меню 
Іпзегі | СЬагі или щелкнуть на кнопке вставки диаграммы панели инстру¬ 
ментов для вставки объектов в отчет (табл. 1.3). 

Появляется мастер отчетов СЬагі Ехрегі. 

СЬагі Ехрегі — это диалоговое окно с вкладками. Первая вкладка — Туре 
(рис. 4.1) позволяет выбрать один из 14 предопределенных типов диаграмм. 
После выбора типа диаграммы можно использовать прочие вкладки и до¬ 
полнительные опции выбора данных, размещения текста к диаграмме и т. д. 
Рассмотрим каждую вкладку подробно. 

Для выбора типа на вкладке Туре диаграммы следует щелкнуть на соответст¬ 
вующей строке в левом списке. После этого в правой части вкладки показы¬ 
ваются подтипы выбранного типа диаграммы. Для выбора подтипа необхо¬ 
димо щелкнуть на соответствующей кнопке. Рассмотрим основные типы 
диаграмм. 

□ Ваг — показывает значение функции в виде полосок. На такой диаграм¬ 
ме хорошо видны относительные значения каждой величины. Диаграмма 
типа Ваг имеет шесть подтипов, в том числе: 8і«1е Ьу 8ійе Ьаг сЬагі и 
8іаскеё Ьаг сЬагі. Диаграмма 8Ые Ьу зігіе Ьаг сЬагі отображает данные как 
серию вертикальных полосок. Этот тип рекомендуется для отображения 
значений функции одного аргумента, например таких, как объем продаж 
в различных городах. Диаграмма Зіаскеіі Ьаг сЬагі отображает данные как 
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серию разделенных вертикальных полосок. Такая диаграмма будет наглядно 
отображать объем продаж в различных городах за последние годы. Полоска, 
соответствующая каждому городу, будет разделена на несколько частей. 

□ Ьіпе — представляет данные в виде нескольких точек, соединенных ли¬ 
нией. Такая диаграмма хорошо подходит для отображения данных 
с очень большим количеством числовых значений. 

□ Агеа — изображает данные в виде цветных областей. Эта диаграмма под¬ 
ходит, когда важно отобразить как абсолютное значение, так и процент¬ 
ное соотношение. 

□ Ріе — изображает данные в виде круга, разделенного на сегменты. Такая 
диаграмма удобна для отображения относительной доли какой-либо ве¬ 
личины. Подтип Микіріе Ріе изображает данные в виде нескольких кру¬ 
гов, разделенных на сегменты. 

□ ВоидЬшй — подобен типу Ріе, но изображает данные не в виде круга, 
а в виде кольца. Имеет подтип МиШрІе Ріе Оои§Ьпи( — нескольких ко¬ 
лец, разделенных на сегменты. Если нужно отобразить процентное соот¬ 
ношение величин, например, долю продаж в различных городах в зави¬ 
симости от суммарного объема продаж, то удобно использовать тип Ріе 
или І)ои§НгшІ. 



СНагІ Ехрегі 


ЙЙЩйШ 
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Рис. 4.1. Вкладка Туре диалогового окна СНагі Ехрегі 
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П 3-Б Ш«ег — изображает данные в виде трехмерных объектов. Удобна для 
отображения функции двух аргументов, например, если необходимо рас¬ 
смотреть объем продаж различных товаров в разных городах. 

□ 3-Г) ЗигГасе — представляет данные в виде трехмерной поверхности. 

□ XV Зсайег — представляет данные в виде символов на координатной 
плоскости XV. 

□ Кагіаг — представляет данные в виде символов в радиальных координа¬ 
тах. Чем больше величина, тем дальше располагается символ от центра. 

□ ВиЬЫе — представляет данные в виде символов различной величины на 
координатной плоскости ХУ. Диаграмма вида ВиЬЫе похожа на XV 
ЗсаМег, но более удобна для отображения функции двух переменных. 

□ 8Госк — показывает диапазон изменения данных относительно макси¬ 
мального и минимального значения. 

□ ІЧитегіс Ахі$ — отличается от диаграмм Упе и Ваг тем, что по оси абс¬ 
цисс откладываются числовые значения, а не номера строк. 

□ Саи§е — удобна, когда нужно наглядно представить небольшой набор 
значений. Значения откладываются на секторах "циферблата", причем на 
"циферблате" можно задать области различного цвета (зеленую, желтую, 
красную). 

□ Сапй — диаграмма Гантта, предназначена для отображения продолжи¬ 
тельности работ. Каждая запись в отчете, в который вставляется диа¬ 
грамма Гантта, должна иметь поля с датой (временем) начала и оконча¬ 
ния работы. 

Вкладка БаГа (рис. 4.2) позволяет определить, данные из каких полей отчета 
будут использованы при построении диаграммы. Кроме того, на этой вклад¬ 
ке задается расположение диаграммы. В верхней части вкладки в разделе 
РІасетепГ указывается, где будет расположена диаграмма. 

Если выбрана опция Опсе рег герогГ (располагать только в одном месте от¬ 
чета), диаграмма может быть расположена в заголовке (Неагіег) или подвале 
(Рооіег) отчета. Если выбрана опция Гог еасЬ, диаграмма будет расположена 
в заголовке или подвале группы. 

Четыре кнопки, расположенные в левой части вкладки, позволяют выбрать 
тип данных для диаграммы. 

1. А<іѵапсе<і — данные, содержащиеся в секции ОеІаіІ$ — поля базы данных, 
формулы и поля Кшшіп§ Тоіаі 

2. Сгоир — агрегатные данные, содержащиеся в полях Зшптагу, например 
количество клиентов в каждом регионе. 

3. Сго88-ТаЬ — агрегатные данные из таблиц Сго88-ТаЬ. 

4. ОІАР —данные из ОІАР-источников. 
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Рис. 4.2. Вкладка Раіа мастера отчетов СНагі ЕхреП 


При создании диаграмм, основанных на агрегатных значениях, сохраняется 
возможность "высверливания" (БгіН Бо\ѵп) данных. Предположим, создан 
отчет о продажах. Данные сгруппированы по странам, в отчет включено по¬ 
ле Зшшпагу с общим объемом продаж по стране. На основе агрегатных дан¬ 
ных построена диаграмма типа Ріе. Тогда для просмотра детальной инфор¬ 
мации можно перенести указатель на сегмент круга, при этом будет показан 
маркер в виде лупы, и дважды щелкнуть. Такая же возможность имеется и 
для подписей (Ье§еш1) к диаграмме. Более подробно отчеты БгШ Помп будут 
рассмотрены далее. 

Содержимое правой части вкладки зависит от выбранного типа данных. Так, 
если выбран тип Сгоир, то для построения диаграммы нужно указать поле 
отчета, в котором содержится аргумент — раскрывающийся список Оп 
сЬап§е оГ — и поле, в котором содержится значение функции — раскры¬ 
вающийся список 8Ьо>ѵ. 

Для отчетов на основе таблиц Сго88-ТаЬ рекомендуется выбирать тип диа¬ 
граммы ЗБ Швег. В этом случае в раскрывающемся списке ЗуЬгііѵіёеё Ьу сле¬ 
дует указать поле, в котором содержится второй аргумент. 

На рис. 4.2 показан вид вкладки Баіа для типа данных Айѵапсей. В этом 
случае диаграмма строится на основе полей, расположенных в секции 
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ОеіаіІ$. В списке доступных полей необходимо выбрать поле аргумента или 
установить опцию Рог еасЬ гесоггі. В этом случае аргументом будет номер 
строки отчета. Затем в список 81ю\ѵ ѵаіиез следует внести одно или несколь¬ 
ко полей функций. При использовании типа данных Айѵапсей рекомендует¬ 
ся выбирать тип диаграммы ІЛпе или Агеа. 

Вкладки Ахе$ и Орііоп§ появляются, если на вкладке Туре выключена опция 
Аніотаіісаііу сЬаг орііопз. На вкладке Ахе$ (рис. 4.3) можно установить 
координатную сетку (81кнѵ §гі(Піпе$) и масштабировать значения аргументов 
и функции (Баіа ѵаіиез). По умолчанию масштабирование значений аргу¬ 
ментов и функции производится автоматически. 



ІСЬагІ Ехрегі 


нп 


ЯШ 


' лілмгаів 
'■■г; 


Ті-ре 1 Оаіа Ахе* } 0рІЮ л 8 1 Тех! | 


Рис. 4.3. Вкладка Ахеа мастера отчетов СНагІ Ехрегі 


Вкладка Орііопв (рис. 4.4) позволяет задать дополнительные опции отобра¬ 
жения диаграммы. Так, в разделе СЬаг* соіог можно включить или отклю¬ 
чить цвет диаграммы. Если в разделе Баіа роіпіз включить опцию 8Ьо\ѵ ІаЬеІ 
или 8Ь<иѵ ѵаіие, то на диаграмме будет отображаться наименование поля 
функции или его значение. Опция 8Ьо\ѵ Ье§еші позволяет добавить подписи 
к элементам диаграммы. Например, если каждому городу на диаграмме со¬ 
ответствует фигура определенного цвета, в Ье§еші будут включены подписи, 
которые свяжут цвет с городом. Если включить опцию Тгапврагепі 
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Ьаск§гоипф то это сделает диаграмму "прозрачной", другими словами, поля 
отчета будут служить для нее фоном. 



Рис. 4.4. Вкладка Орііопз мастера отчетов СЬагі Ехрегі 


Вкладка Техі позволяет создать текстовые поля, содержащие заголовки, 

подписи к осям и другие пометки. Здесь можно также установить шрифт 

для каждой подписи. 

Упражнение 4.1 

1. Откройте отчет, созданный в упражнении 3.5. 

2. Удалите группировку по странам. 

3. При помощи 8еІесі ЕхреП задайте условие выборки сизсотег. соипегу 
едиаі Ьо "Сапада". 

4. Вставьте диаграмму типа Ріе, отображающую количество клиентов в го¬ 
родах. 

5. Результат выполнения упражнения представлен на рис. 4.5. Справа вид¬ 
ны подписи (Ье§епгі). 

6. Сохраните отчет. 
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Соипі о? Сизіотег Ыате / СИу 


Прочие 



ВеасопзПеій 


Рис. 4.5. Пример диаграммы типа Ріе 


4.2. Сложное форматирование диаграмм 

После создания диаграммы при помощи СЬаг Ехрегі, ее можно отформати¬ 
ровать более тщательно. Для сложного форматирования диаграмм Сгузіаі 
Ксрогй 9 содержит специальный набор диалоговых окон, которые вызыва¬ 
ются из контекстного меню. Для вызова контекстного меню следует пере¬ 
местить указатель на диаграмму и щелкнуть правой кнопкой мыши. 

Пункт контекстного меню Роггааі Сііагі вызывает диалоговое окно Рогтаі 
Ейііог. Это окно во многом похоже на подобное окно, служащее для форма¬ 
тирования полей (рис. 2.15). С его помощью можно задать основные свойства 
диаграммы на вкладке Соішпоп, создать рамку, используя вкладку Вогйег, или 
создать гиперссылку на вкладке Нурегііпк. Пункт контекстного меню 8іхе апё 
Роыііоп вызывает диалоговое окно (Муесі 8йе апй Ровійоп (рис. 4.6), в котором 
можно изменить размер и расположение диаграммы в секции отчета. 



♦ 


Рис. 4.6. Диалоговое окно ОЬіесІ 5іге апгі Розійоп 
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Гпава 4 


С помощью команд меню СЬагІ Орііопз | Сепегаі, СЬагІ Орііопз | Тйіе» и 

СЬагГ Орііопз | Тешріаіе вызываются дополнительные диалоговые окна фор¬ 
матирования. 

Диалоговое окно СЬагІ Орііопв (рис. 4.7) можно также вызвать с помощью 
команды каскадного меню СЬагІ Орііопд | Сепегаі. 


СНаіі 0(йюп$... 


Ш 


(6епегаГ| Цда*} 6а{а ІаЪёЦ)| 'ІоЫе ■ | рі$р!ау $Мш ) 


к ѵЙІУ 


Й - Ве5іоге ДІІ'ЗІІсёа .| " : 

IІЦІІІ 


ѵ ^Ті# —ц— 


Щ{2од: 


Соипі сЛ Си5Іотег 
Ыате / Сііу 


-"-п ■' Ріе Вірік —3--- (50 3 

зег ! •■ •■. - ' М' ' ѵ-'.'-йл 1 .-•••.•• ■ . 



І;;'ре Во^аіш:*—І“ 
ЕйрІоЙе Ріе: г 


|Э0 3 

Г“3. 




Ю;_ 


Сапсёі 


Рис. 4 . 7 . Диалоговое окно СЬагГ Орііопз 


Вкладка Сепегаі является контекстной, т. е. ее содержимое зависит от типа 
диаграммы, и позволяет установить визуальные свойства диаграммы. Так, 
для типа Ріе доступны свойства: 

□ Тік задает угол зрения; 

□ Бер* — высоту сегментов; 

□ Коіаііоп — угол поворота; 

□ Ехріоёе — расстояние между сегментами; 

□ Ноіе 8іхе — толщину кольца. 

Вкладка Ьауоиі позволяет изменить подтип диаграммы, например, для типа 
Ріе выбрать между кругом и кольцом. Вкладка Оаіа ЬаЬеІ8 позволяет ввести 
подписи к сегментам или полоскам. На вкладке ЗЧитЬеге можно изменить 
формат изображения чисел. Вкладки Ьоок и Оівріау 8іаііі8 позволяют форма¬ 
тировать подписи к диаграмме, например, Ье§епі1 или подписи к сегментам. 

Команда меню СЬагІ ОрІіоп8 1 ТШев вызывает диалоговое окно Тіііев 
(рис. 4.8), в котором можно отредактировать заголовок, подзаголовок диа¬ 
граммы ^примечание. 

При создании отчета высокого качества настройка диаграммы может быть до¬ 
вольно трудоемка. Для повторного использования настроек СгузГаІ КероПд 9 
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позволяет сохранить шаблон диаграммы (не путать с шаблоном отчета). Лю¬ 
бую диаграмму можно сохранить как шаблон. Для этого следует щелкнуть 
правой кнопкой на диаграмме и выбрать в контекстном меню пункт 8аѵе а$ 
Тешріаіе. Кроме того, Сгузіаі Керогіз 9 содержит библиотеку готовых шабло¬ 
нов. Чтобы воспользоваться шаблоном, нужно выполнить команду контек¬ 
стного меню СЬагЧ Орііопз | Тешріаіе Возникает диалоговое окно СЬоозе 
а СІіаіі Туре (рис. 4.9). Вкладка баііегу содержит стандартные шаблоны, 
вкладка Си$1ош — дополнительные, в том числе созданные пользователем. 



Рис. 4.8. Диалоговое окно ТіМез 



Рис. 4.9. Диалоговое окно СНоозе а СНаП Туре 
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Для форматирования отдельного элемента диаграммы, например сегмента круга 
или прямоугольника, используются диалоговые окна 8егіе§ Орйопз и РогшаШп^. 
Для вызова этих окон следует переместить указатель на элемент диаграммы, 
щелкнуть правой кнопкой мыши и выполнить команду контекстного меню 

СЬагі Орііопк — 8егіе8 и СЬаг* Орііоп8 | 8е1есіегі Нет соответственно. 

Диалоговое окно Зегіев Орйоп$ (рис. 4.10) позволяет изменить подпись и 
расположение фрагмента диаграммы, например, изменить расстояние до 
центра сегмента круга (опция БеГасЬ 81ісе на вкладке Сепегаі). Кнопка 
Беіеіе 8Нсе служит для удаления выделенного фрагмента диаграммы, кнопка 
Кевіоге — восстановления удаленного фрагмента. Вкладка Баіа ЬаЬеІ8 со¬ 
держит радиокнопки, позволяющие скрыть или показать подписи фрагмен¬ 
тов диаграммы, а также изменить их расположение. 



На вкладках диалогового окна ГоппаШщ» (рис. 4.11) можно изменить шрифт 
объекта (вкладка Ропі), стиль и цвет обрамляющей линии (вкладка Ілпе) и 
заливку (вкладка ГШ). Помимо палитры цветов, СгуЫаІ Кероіік 9 содержит 
библиотеки градиентных заливок (кнопка Сгаёіепі), текстур (кнопка 
Техішге) и рисунков (кнопка Рісіиге). 

Кнопка Рісіиге вызывает диалоговое окно СЬоозе а Рісіиге (рис. 4.12), в ко¬ 
тором содержится набор рисунков. Набор рисунков можно пополнить из 
библиотек Місгохой О Шее сіір агі. Для этого следует сначала щелкнуть на 
кнопке Агіѵапсегі Орііоп.8. а затем на кнопке Вго\Ѵ8е и выбрать файлы биб¬ 
лиотеки с расширением \ѵшй 

Выбранный рисунок отобразится на редактируемом элементе. Пример диа¬ 
граммы с отображением рисунков на элементах приведен на рис. 4.13. 



































Рис. 4 . 13 . Пример диаграммы с отображением рисунков на элементах 


Диалоговое окно ІЧшпегіс Ахі$ Сгіёв & 8саіе$ (рис. 4.14) вызывается коман¬ 
дой меню СЬагі Орйоп$ | Сгіё и служит для форматирования координатной 
сетки. Заметим, что оно недоступно для диаграмм типа Ріе. Для трехмерных 
диаграмм диалог имеет два ряда вкладок — по горизонтали и по вертикали. 



.6ёйШ' 


Аквоп Іей Ѵ/аЙ * ^ -| 

Г" Ахк опВідЫѴаЯ ; : 

(Т тЕсЛ 

Г*' ОоШЭіай Ш оІБсгІё ѴаІиёіѵЙІ 


Про Канады 


СапсУ 


Рис. 4 . 14 . Диалоговое окно Ыитегіс Ахіа Сгісіе & Зсаіез 


Вкладки, расположенные по вертикали, позволяют выбрать тип координат¬ 
ной сетки: Баіа Ахі§ — координатная сетка по вертикали, Сгоир Ахів и 
Зегіе» Ахі8 — по двум другим координатам. Горизонтальная вкладка Сгі<І8 
служит для включения и выключения координатной сетки. Вкладки ЬаЬеІ$ и 
ІЧитЬегБ позволяют ввести подписи к осям и задать их формат. Во вкладке 
8са1е8 задается масштаб данных на осях. 
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Рис. 4.15. Диалоговое окно СНоо&е а Ѵіеѵѵіпд Апдіе 


Диалоговое окно СЬоозе а Ѵіе\ѵіпе Ап§іе позволяет выбрать точку зрения на 
трехмерную диаграмму. Рис. 4.15 показывает вид диалогового окна Сіюозе 
а Ѵіеіѵііц» Ап^іе после щелчка на кнопке Айѵапсегі Орйопз. Кнопка исчезает, 
и появляется инструмент изменения угла зрения. Вкладка КоШе позволяет 
вращать изображение, вкладка Рап — изменять "удаление" до изображения, 
\Ѵа1І8 — менять толщину стенок координатных плоскостей, Моѵе — пере¬ 
мещать изображение. 

^ Примечание 

Пакет Сгузіаі Верогіз 9 содержит типовые отчеты с диаграммами — СЬагІ.грІ и 
Етріоуее Заіез.грі. Их можно найти в каталогах Ргодгат РіІез\СгузІаІ 
ОесізіопзЮгузІаІ ВероНз 9\ЗатрІез\Еп\ВерогІ5\РеаІиге Ехатріез и Ргодгат 
РІІез\Сгуз1аІ Оесізіопз\Сгуз(аІ Яерогіз 9\ЗатрІез\Еп\ВерогІ5\СепегаІ Визіпезз 
соответственно. 


4.3. Вставка географических карт 

Сгузіаі Керогіз 9 позволяет включить в отчет географические карты и связать 
с ними данные отчета. Карты могут быть отформатированы, кроме того, при 
работе с картами сохраняется возможность "высверливания" (<ігі11-сіо\ѵп) 
данных. Привязка данных к географическим картам делает отчет нагляднее. 
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эффективно выявляет тенденции и, тем самым, дает возможность произве¬ 
сти более качественный анализ. 

Для внесения в отчет географической карты следует щелкнуть на кнопке 
вставки географической карты в панели инструментов для вставки объектов 
в отчет (табл. 1.3) или выполнить команду меню Іп$егі | Мар. Появляется 
диалоговое окно Мар Ехрегі, которое содержит три вкладки: Баіа, Туре и 
Техі. 



Оаіа | Туре ] Тех! 
рРІасепіегЛ — - - 


Ріасе тар: 


,;|гГауоуІ 


Асіѵагюеіі 


ДлсНэпдеоГ | Си$Іотег Ведіоп 


]5ит оі Сийотег.іай Ѵеаг'5 Заіег 


Мар Ехре>( 


Рис. 4.16. Вкладка Оаіа диалогового окна Мар Ехрегі 


На вкладке Баіа (рис. 4.16) задается тип данных, которые будут связаны 
с географической картой. Если выбрана опция Опсе рег герогі (располагать 
только в одном месте отчета), карта может быть расположена в заголовке 
(Неагіег) или подвале (Рооіег) отчета. Если выбрана опция Гог еасЬ, то карта 
будет расположена в заголовке или подвале группы. Так же как и диаграм¬ 
ма, географическая карта может быть связана: 

□ кнопкой Сгоир с агрегатными данными, содержащимися в полях $шшпагу; 

□ кнопкой Аёѵапсей с данными, содержащимися в секции Оеіаіів; 

□ кнопкой Сго88-ТаЬ с агрегатными данными из таблиц Сго88-ТаЬ; 

□ кнопкой ОІАР — с данными из ОЬАР-источников. 
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Если географическая карта связана с данными, содержащимися в секции 
Пеіаіів, на вкладке появляется несколько полей и списков. С помощью 
кнопки > поля данных из списка доступных полей (АѵайаЫе Ріеійк) заносят¬ 
ся в списки полей Оп сЬап§е оГ, Сео§гарІііс Пеіё и Мар ѵаіие, а с помощью 
кнопки < удаляются из этих списков. Опция Оп сЬап§е оГ используется как 
условие для суммирующего поля, значение поля Мар ѵаіие будет использо¬ 
вано для отображения на карте. 

В правой части вкладки нужно указать поле, содержащее географические 
названия (ОеорарНіс йеігі), например поле, содержащее названия стран, об¬ 
ластей, городов и т. д. 

Сгувіаі КероЛз 9 поддерживает стандарт геоинформационной системы 
МарІпГо При инсталляции С гуда! Керопз 9 устанавливается утилита 
Сеосіісгіопагу Мапа^ег (рис. 4.17) и автоматически регистрируется набор 
географических карт. Значение поля Сео§гар№с Пе1(1 должно совпадать со 
значением поля таблицы географических карт. Для регистрации дополни¬ 
тельной географической карты необходимо щелкнуть на кнопке Пуск 
(ЗіагІ), затем выбрать пункт меню Выполнить (Кип) и в диалоговом окне 
Запуск программы (Кип) указать файл \Рго§гаш РіІезѴМарІпГо МарХ\ 
Рго§гат\Мі§тЗО.ехе. 
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Рис. 4.17. Диалоговое окно утилиты Сеосіісііопагу Мападег 


С помощью утилиты Сеоёісйопагу Мападег необходимо указать файл 
СеосІісПопагу с расширением бсі. Если щелкнуть на кнопке Ргореггіез, откроет¬ 
ся диалоговое окно ТаЫе Ргореггіез (рис. 4.18), в котором можно просмотреть 
поля, содержащие географические названия, и изменить свойства таблицы. 
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Гпава 4 


’ ТаЫе Рюресііег 


МарМоТаМе: |А$іаТДВ 

Оезсфіюл: ‘ |Азіа 
Йвмпйгу Туре: Всипоіагу 


Г:еИ ІЫогтаІюп - - - .-.- . 

СРе'ска ВеИ’а ЗеагсЬ Ьох ііуои ѵ/ап { МарХІо 
зеагсЬ Иіаі «іеИ уурвп таісріпд іИе йаіа ігі уоцг 
ѵѵогкаНей. 

ВеИЫагов . Зеагсл 


• СапсМаІе СеозеЫо ^оасі !< Маісііесі -! 






АЙЙ... 


Вещдуе 




Салсеі 


ш 


Рис. 4.18. Диалоговое окно ТаЫе Ргорегііев 


Вкладка Туре диалога Мар Ехрегі (рис. 4.19) позволяет выбрать один из пя¬ 
ти возможных типов карты. 

□ Каплей — географические области закрашиваются с интенсивностью, 
пропорциональной отображаемой величине. Например, если создается 
карта, показывающая количество людей, проживающих в каждом регио¬ 
не, то можно ввести условие, что каждому оттенку будут соответствовать 
интервалы 0-5000, 5001-10000, 10001—15000, 15001-20000 и более 20000 
человек. Для закраски областей удобно выбрать оттенки одного цвета, 
например, регионы с наибольшим населением показать темно-зеленым 
цветом, с наименьшим — светло-зеленым. Количество оттенков, как и 
количество учитываемых групп, можно изменять. Есть четыре алгоритма 
распределения интервалов; 

• Ециаі соипі — интервалы распределяются так, чтобы число регионов 
в одном интервале было примерно одинаковым, сами интервалы будут 
различными; 

• ЕдиаІ гап§е$ — каждому интервалу соответствует одинаковый количест¬ 
венный диапазон, например 0—5000, 5001—10000, 10001-15000 и т. д.; 

• Каіигаі Ьгеак — алгоритм, по которому минимизируется разница меж¬ 
ду суммарным значением и средним значением от суммарного для ка¬ 
ждого интервала; 

• 8іап(1аг(і йеѵіаііоп — интервалы рассчитываются на основе среднеквад¬ 
ратичного отклонения. 
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Рис. 4.19. Вкладка Туре диалога Мар Ехрегі 

□ Боі Бепзііу — области заливаются узором из точек. Количество точек 
пропорционально отображаемой величине. Чем больше величина, тем 
большая плотность точек будет отображаться в области на географиче¬ 
ской карте. 

□ Сгайиаіей — в каждой области показывается один символ. Размер симво¬ 
ла пропорционален отображаемой величине. Тип символа можно изме¬ 
нить (кнопка Сизіот), это может быть любая литера из любого шрифта. 

□ Ріе СЬагІ — на фоне карты показывается диаграмма типа Ріе. 

□ Ваг СЬаіі — на фоне карты показывается диаграмма типа Ваг. 

Вкладка Тех* служит для внесения заголовка географической карты и изме¬ 
нения подписей (Ье§епй) к карте. 

Если щелкнуть на кнопке ОК в редакторе Мар Ехрегі, географическая карта 

будет включена в отчет (рис. 4.20 и 4.2 І). 

Для редактирования географической карты служит контекстное меню 

(табл. 4.1), которое можно вызвать, щелкнув на карте правой кнопкой 


мыши. 









Рис. 4.20. Вид географической карты в режиме Оезідп 



Рис. 4.21. Вид географической карты в режиме Ргеѵіеѵѵ 


Таблица 4.1. Пункты контекстного меню редактирования географической карты 


Пункт меню 

Описание команды меню 

Мар Ехрегі 

Вызов диалогового окна Мар Ехрегі (рис. 4.16) 

Рогтаі Мар 

Вызов диалогового окна Рогтаі Есіііог. Диалоговое окно 
Рогтаі Есіііог аналогично окну для форматирования полей, 
которое было рассмотрено в разд. 2.2 (рис. 2.15). С его по¬ 
мощью можно отформатировать карту, изменить ее рамки и 
установить гиперссылку 

Зіге апсі Розіііоп 

Вызов диалогового окна ОЬ)есі Зіге апсі Розіііоп (рис. 4.6), 
служащего для изменения размера и расположения карты 

Зеіесі МоВе 

Переход в режим выбора карты 

2оот Іп 

Увеличение масштаба. Для увеличения масштаба следует 
выбрать пункт меню 2оот Іп и затем щелкнуть на карте 

2оот Оиі 

Уменьшение масштаба. Для уменьшения масштаба следует 
выбрать пункт меню 2оот Оиі и щелкнуть на карте 
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Таблица 4.1 (окончание) 

Пункт меню 

Описание команды меню 

Рап 

Перемещение карты. Для перемещения карты следует выпол¬ 
нить команду меню Рап и переместить карту методом 
Огад&Огор 

Сепіег Мар 

Центровка карты. Для центровки карты следует выбрать пункт 
меню Сепіег Мар и щелкнуть на карте 

ТШе 

Вызов диалогового окна СНапде Мар ТШе для изменения за¬ 
головка карты 

Туре 

Вызов диалогового окна Сизіотіге Мар для изменения опций 
закрашивания зон карты 

Ьауегз 

Вызов диалогового окна Ьауег СопігоІ для изменения слоев 
карты 

Везоіѵе МіетаІсН 

Вызов диалогового окна Вееоіѵе Мар МізтаісН для разре¬ 
шения противоречий между данными географического поля 
отчета и данными карты 

Мар Ыаѵідаіог 

Вызов окна Мар Ыаѵідаіог 


Для изменения заголовка карты в контекстном меню выбрать пункт ТШе. 
В появившемся диалоге СЬап§е Мар ТШе (рис. 4.22) следует изменить заго¬ 
ловок карты и щелкнуть на кнопке ОК. 


СНапде Мар ТіІІе 


щ 


Продажи е США] 


V,- 


•Р*- 3 Сапсеі \ 


Рис. 4.22. Диалоговое окно СНапде Мар ТШе 


Чтобы изменить тип и настройки отображения карты, можно вернуться 
в диалоговое окно Мар Ехрегі. однако существует более короткий путь. Ес¬ 
ли в контекстном меню выбрать пункт Туре, появится диалоговое окно 
Сшйотіге Мар (рис. 4.23), в верхней части которого расположен раскры¬ 
вающийся список, содержащий типы карт. Содержание нижней части окна 
зависит от выбранного типа. Так, для типа Кап§е<і можно изменить опции 
закрашивания зон карты, для типа Боі Вепзііу — размер точек, составляю¬ 
щих узор, для типа Сгаёиаіеё — стиль символов. 

Географическая карта в формате МарІпГо содержит несколько слоев. Слой 
карты может, например, содержать города, или реки, или границы областей. 
Диалоговое окно Ьауег Сопігоі (рис. 4.24) позволяет изменить состав и оче¬ 
редность слоев карты. 
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Гпава 4 



МитЬег Ы Неіѵак 


ЦЫііЬиІіоп теІЬоЗ: 


ЁциаІ гапдез 
Маіигаі Ьіеак 
Зіаггіакі гісуіыіогі 
|| ' | Ааиа 


СоІо( о? НідНей іпіегѵаі: 


Сйіоі сі !отее« іпіеіѵак 


(ѵ АНои егпріу іпіеіѵаіз 


Сизіотіге Мар 


Рис. 4.23. Диалоговое окно Сивіотіге Мар 



У$ Сарііаі* 


Іі$ Маіог СШе$ 

Ы5 Сі(іез 
Іі$ НідЬ^ауз 
Сапасіа 
Мехісо 

І_І5 СоипІѵВоипгіагіе$ 


ІОсеап [Іаі/Іопд] 


:р Р*ореДіе$ 

I Р Ѵк«Ые 

^ійопіайд і»аЬЫ$ 


СапсЫ 


I І ауег Сопігоі 


Іауега: 


Рис. 4.24. Диалоговое окно Ьауег СогНгоІ 


Содержимое географического поля может не совпадать с данными геогра¬ 
фической карты. Например, в таблице карты может содержаться название 
страны Шііесі Кіп§<іот, а в отчете может соответствовать ему значение ІЖ. 
Для разрешения противоречий используется диалоговое окно Ке$о1ѵе Мар 
МівтаісЬ, содержащее две вкладки — СЬап§е Мар и Кекоіѵе МізтаІсЬ. За¬ 
регистрированная с помощью утилиты Сеойісііопагу Мапа§ег карта, которую 
подключает по умолчанию Сгузіаі КероЛ$ 9, может оказаться неподходящей 
для создаваемого отчета. Вкладка Сііаіще Мар (рис. 4.25) позволяет переоп- 
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ределить подключенную карту. Для переопределения карты следует пере¬ 
местить указатель на строку с наименованием карты в списке АѵаіІаЫе Мар. 
В окне Зеіесіеё Мар отображается выбранная карта. 



СНапдеМар | Вкоіѵе МіяпаІсЬ ) - 

Іп ІЬіі,раде;,Й-іе сиігепі тар сап Ье сЬапдей тіо агіу тар іп іЬе аѵаіІаЫе тар$ И Ьеіоѵ* 


іп пегірадв, ІЬе: циаІІІу.й іЬе'аеІасІесІ тар сап Ье ітргоѵес! Ьу геайіуіпд Ше'таррпд сіаіа 
твтаІрЬеа 


Сигіепі тар: : • :05А 


йѵ.аіІаЫе тара; 


^рап Маіог Сіііе® 
Менісо 

Мехісо СарііаЬ 
Браіп 
У К Сіііев 
Ііпііесі Кіпдсіот 
Ц 5 Сарііаіз 


:Ніеадо- 


(ШЩ 


іРЬоепк 


ІОаІІаз 


Ѵ/огИ 

Ѵ/огИ Сарііаіз 
Ѵ/огИ Маіог Сіііеа 


Юа^к'зсп^! 


Отмена 


Ш Вехоіѵе Мар МізтаісЬ 


Рис. 4 . 25 . Вкладка СЬапде Мар диалогового окна Невоіѵе Мар МівтаІсН 


Во вкладке Кекоіѵе Міыпаісіі (рис. 4.26) показываются географические имена, 
не соответствующие значению полей отчета. Для разрешения противоречия 
в списке А$$і§п іЬІ8 Ріеій Nаше следует выбрать значение поля отчета, затем 
выбрать значение из списка То Й 1 І 8 Мар Каше, после чего щелкнуть на кноп¬ 
ке МаІсЬ Соответствие полей показывается в списке Маісііесі ге$и1І8. После 
разрешения всех противоречий следует щелкнуть на кнопке ОК. 

Увеличение масштаба карты (2оош Іп) и перемещение (Рап) приводит к то¬ 
му, что в отчете показывается только часть карты, причем иногда оказывает¬ 
ся сложно определить, какая именно часть. Для навигации по карте исполь¬ 
зуется окно Мар №ѵі§а(:ог (рис. 4.27). Этот инструмент позволяет взглянуть 
в мелком масштабе на положение отображаемого фрагмента карты относи¬ 
тельно целой карты. Текущее положение обозначается прямоугольником на 
целой карте. Мар Каѵіріог поддерживает перемещение карты. Для переме¬ 
щения достаточно сдвинуть прямоугольник в окне Мар Шѵі[»аіог методом 
Ога§&Огор. Скрыть Мар Маѵі^аіог можно, выключив опцию Мар Маѵщаіог 
в контекстном меню. 
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Рис. 4.26. Вкладка Невоіѵе МівтаТсЬ диалогового окна Иевоіѵе Мар МівтаІсН 



Рис. 4.27. Окно Мар Маѵідаіог 






















Глава 5 


Использование формул 



5.1. Рогтиіа ѴѴогкзЬор — 
среда создания формул 

В отчетах часто возникает необходимость отображать поля, которые не со¬ 
держатся в базе, но могут быть вычислены. Для этого СгумаІ Керогіз 9 со¬ 
держит эффективный инструмент — язык описания формул. 

Чтобы создать формулу, достаточно в списке полей окна Ріеіё Ехріогег пе¬ 
реместить указатель на строку Рогтиіа Ріе1гі$ и щелкнуть кнопкой мыши на 
кнопке создания объекта (табл. 2.1). 

Появляется диалоговое окно Рогтиіа №те (рис. 5.1) для ввода имени фор¬ 
мулы. 



Рис. 5.1. Диалоговое окно Рогтиіа Мате 


В поле ІЧате следует ввести имя формулы и щелкнуть на кнопке ІІ8е Ехрегі 
или ІІ8е Еёііог. Появляется диалоговое окно Рогтиіа \Ѵогк8Іюр (рис. 5.2). 

Рогтиіа \Ѵогк8Іюр представляет собой универсальную среду, позволяющую 
создавать или изменять следующие объекты: 

□ специальные функции отчета; 

□ специальные функции, размещенные в хранилище (Керозйогу); 

□ формулы для вычислений и преобразований данных отчета; 

□ 8()Ь-выражения; 

□ формулы для выборки данных; 
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□ формулы для форматирования данных; 

□ формулы для создания специальных сообщений (КероЛ АІеЛ) отчета. 
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Рис. 5.2. Диалоговое окно Рогтиіа ѴѴогкаНор с окном Рогтиіа ЕгіИог 


По умолчанию в левой части диалогового окна Рогтиіа ѴѴогквЬор располо¬ 
жен древовидный список, содержащий набор папок для каждого типа объ¬ 
ектов, в верхней части — панель инструментов (табл. 5.1), Древовидный 
список функций и формул является перемещаемым. 

Таблица 5.1. Элементы управления панели инструментов 
диалогового окна Рогтиіа ѴѴогкзНор 


Элемент Описание элемента 

управления 


ѵг СІо$е 



Х> 

X 



Сохранение формулы и закрытие диалогового окна Рогтиіа 
ѴѴогкзЬор. Перед закрытием окна проверяется синтаксис форму¬ 
лы 

Создание новой формулы, функции, определяемой пользовате¬ 
лем или ЗОЬвыражения. Раскрывающийся список позволяет вы¬ 
брать тип создаваемого объекта 

Переименование формулы, функции, определяемой пользовате¬ 
лем или ЗОЬвыражения 

Удаление формулы, функции, определяемой пользователем или 
ЗСИ-выражения 

Показать или скрыть список функций и формул 


Раскрыть или свернуть список функций и формул 

Показать или скрыть объекты в разделе формул форматирования 
(Рогтайіпд Рогтиіаз) списка функций и формул, которые не свя¬ 
заны с формулами форматирования 
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Таблица 5.1 (окончание) 


Элемент Описание элемента 

управления 





Переключение между окнами Сизіот Рипсііоп ЕсШог и Сизіот 
Рипсііоп Ргорегііез 

Открыть диалоговое окно Орепз ійе Асісі Сизіот Рипсііоп іо 
Яерозііогу для внесения специальной функции в хранилище 

Внести выбранную специальную функцию из хранилища в отчет 


Если создается или изменяется формула или ЗОЬ-выражение, то в правой 
нижней части содержится окно Гогтиіа Егіііог, если же создается или изме¬ 
няется специальная функция, то окно Гогтиіа Ехрегі. 

Окно Гогтиіа Ейііог (рис. 5.2) содержит панель инструментов и четыре ок¬ 
на. Элементы управления панели инструментов Гогтиіа ЕЛііог приведены 
в табл. 5.2. Окно полей содержит древовидный список полей отчета, специ¬ 
альных полей, агрегатных полей, формул и полей базы данных. Окно функ¬ 
ций содержит древовидный список функций. Функции представляют собой 
предопределенные процедуры, возвращающие значение. В списке функции 
отсортированы по типам. Окно операторов содержит список операторов, 
использующихся в формулах. 

В нижней части Гогтиіа ЕФіог размещается окно с текстом формулы. Если 
дважды щелкнуть по наименованию формулы поля, наименованию функции 
или наименованию оператора в соответствующем списке, то текст формулы 
выводится в это окно для редактирования. 

Если установить указатель на какой-либо фрагмент формулы в нижней час¬ 
ти окна и нажать комбинацию клавиш <Сіг1>+<Пробел>, то появляется 
список доступных функций и служебных слов, из которых можно выбрать 
необходимое. 

Все окна и панель инструментов Гогтиіа Егіііог перемещаемые — можно 
расположить их так, как удобно. 

Таблица 5.2. Элементы управления панели инструментов окна Рогтиіа Ебііог 


Элемент Описание элемента 

управления 



Сохранение формулы. Перед закрытием окна проверяется 
синтаксис формулы 

Проверка синтаксиса. В случае обнаружения ошибки выдается 
сообщение 
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Таблица 5.2 (продолжение) 


Элемент Описание элемента 

управления 



Отмена действия (1)пск>) 


Повтор действия (Небо) 

Просмотр значения полей. Появляется редактор просмотра 
значения поля, Чтобы внести значение поля в текст формулы, 
достаточно дважды щелкнуть на соответствующей строке 
в списке значений 

Поиск. Поиск осуществляется в тексте формулы 

Установка меток, В тексте формулы меткой может быть поме¬ 
чена строка целиком. Метки в Рогтиіа Егіііог используются 
только для навигации 

Переход к последующей метке 
Переход к предыдущей метке 
Удаление всех меток 


Изменение порядка функций или операторов. Функции и опе¬ 
раторы могут быть отсортированы как по типу, так и по алфа¬ 
виту 

Включение и выключение окна полей 


Включение и выключение окна функций 

Включение и выключение окна операторов 

Выбор синтаксиса. Сгузіаі Перогіз 9 поддерживает два синтак¬ 
сиса для формул — традиционный синтаксис СгузіаІ Вероііз и 
синтаксис ѴізиаІ Вазіс, Один отчет может содержать формулы, 
написанные в разном синтаксисе, однако одна формула не 
может содержать фрагменты, написанные в разных стилях. 
В настоящей книге рассматривается только синтаксис Сгузіаі 
Пероііз 9 


Внесение комментария. Щелчок на этой кнопке приводит к 
тому, что в начало текущей строки добавляется два символа /, 
после чего данная строка считается комментарием (разд. 5.2) 
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Таблица 5.2 (окончание) 


Элемент Описание элемента 

управления 

~~^Г- Вызов окна Рогтиіа Ехрегі 

ГЗГП Вызов справки 


Окно Рогтиіа Ехрегі (рис. 5.3) позволяет создавать, изменять и вносить спе¬ 
циальные функции в отчет. В левой верхней части окна расположен древо¬ 
видный список специальных функций. В поле Зшшпагу показывается опи¬ 
сание функции, в поле Кеіигп Туре — тип возвращаемого значения 
функции. Для внесения специальной функции в отчет необходимы следую¬ 
щие действия: 

1. Переместить указатель в списке специальных функций на строку с тре¬ 
буемой функцией. 

2. В списке Рипсііопз Аг§шпепі8 указать значения аргументов. 

3. Щелкнуть на кнопке 8аѵе. 

Щелчок на кнопке Ше Егіііог открывает окно Рогтиіа Ейііог, причем в окно 
с текстом формулы добавляется специальная функция. 



03 :$ Гоіта» 


Іпсгеа$е а сигтепсу Ьу а діѵеп рвгсепіаде. Рог ехатріе, і Нте ѵаІиеТоіпсіеазе і$ $200 

апсі ретсепіТ оІпсгеа$е ФІО ІЬео іЬе ге$иІІ і$ $220. ^ 


ш БеодгарЬіс 
Ггі % МаіЬ _ 

: 9 ссііпсіеазеЫитЬегВуАРеісеШаде 
Ф ссІРасепІадеРіИегепсе 


рипс^^ 


лжепсу; 


Сйгіепс^ і : с^ягепсу уаіив го ігй?геа?ѳ Ъу а регсёгйедѳ; ; ®э Си«Ьпеі.и$1 ѴеагЪ 8аІе$ 
:Ышфё{;:ѵре*стІр;іпсгеа5ё ѵаІиеЬу е-д.Ір ; . I 20 


Рис. 5.3. Окно Рогтиіа Ехрегі 


4 Зак. 1021 
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5.2. Синтаксис формул 

Как было указано ранее, Сгузіаі Керогіз 9 поддерживает два типа вида син¬ 
таксиса — синтаксис Сгузіаі и синтаксис Вазіс. Любая формула, написанная 
по правилам Сгізіаі, может быть переписана по правилам Ва$іс и наоборот. 
Отчет может содержать формулы обоих типов. Синтаксис Сгузіаі традицио- 
нен для Сгузіаі Яерогіз, его поддерживают все предыдущие версии этого 
продукта. Синтаксис Вазіс введен только в версии Сгузіаі Керогіз 8.0. 
Он похож на синтаксис МісгозоГі Ѵізііаі Вазіс за исключением выражений, 
которые отвечают за управление отчетом. Ниже будет рассматриваться син¬ 
таксис Сгузіаі. 

Формулы Сгузіаі Керогіз 9 могут содержать следующие компоненты. 

□ Поля отчета или поля базы данных, которые выбираются из списка по¬ 
лей или вносятся вручную. Эти компоненты заключаются в фигурные 
скобки: {Сизіотег.ілзі Ѵеаг'з 8а1ез}, {Сизіотег.Сііу}. 

□ Числа: 1, 2, 3.1416, здесь точка отделяет дробную часть действительного 
числа. 

□ Текст, заключенный в двойные кавычки: "Итого сумма по отчету". 

□ Операторы выбираются из окна операторов или вводятся вручную. Это 
могут быть арифметические операторы (/, *, +, -), булевы операторы 
(апд, ог), операторы сравнения (<, >,=) и другие. 

□ Функции, в том числе агрегатные и специальные: Зшп (х, {сизіотег.СіІу}), 
ссПпсгеазеСиггепсуВуАРегсепіа§е ({Сизіотег.ТазІ Уеаг'з Заіез}, 20), Тгіпт 
(х). Аргументы функции заключаются в круглые скобки и разделяются 
запятой. Вторым аргументом агрегатной функции 5шп(х, {Сизіотег.Сііу}) 
является поле, по которому произведено группирование. Функция может 
быть выбрана из списка функций или внесена вручную. Подробнее 
функции рассмотрены в разд. 5.3. 

П Структуры управления: ІГ, Зеіесі или оператор цикла Рог. Структу¬ 
ры управления могут быть выбраны из окна операторов или внесены 
вручную. 

□ Другие формулы отчета, например {@СгоззРгоГіІ}, {@фІЮТА}. Имя фор¬ 
мулы заключается в фигурные скобки и начинается символом @. Форму¬ 
лы выбираются из окна полей или вносятся вручную. Несмотря на то, 
что в окне полей показывается имя текущей формулы, в тексте формулы 
его использовать нельзя. 

□ Переменные. Перед использованием переменные должны быть предвари¬ 
тельно описаны в формуле. Сгузіаі Дерогіз 9 поддерживает переменные 
типа массив (аггау). Индекс массива заключается в квадратные скобки: 
МуАггау[5]. 
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Комментарий к формуле отделяется символами //. 

В формуле могут также использоваться параметры, поля гиппіп§ іоіа], поля 
ехргеззіоп, специальные поля, суммирующие поля и имена групп. Эти 
элементы могут быть выбраны из списка полей или внесены вручную. 

□ Параметры заключаются в фигурные скобки. Имя параметра начинается 
со знака ?, например: 

{?шу рагатеЪег Іііеісі} . 

□ Имя поля птпіп§ тоіаіз начинается со знака #: 

{#шу гиппіпд ЬоЬаІ} . 

□ Поля 8()Ь ехргеззіоп начинаются со знака процента: 

{%ту 8<2Ц ехргеззіоп} . 

□ Суммирующие поля и имена групп, похожие на вызовы функций: 

Вит( {Огсіегз . Огсіег АтоипЬ}, {Огсіегз . ЗЬір Ѵіа> ) 

СгоирЦате ( {Огсіегз . ЗЪір Ѵіа} ) . 

Каждая формула должна возвращать значение одного из семи типов: 
МшпЬег, Сштепсу, 8ігіп§, Вооіеап, Оаіе, Тігпе или ОаіеТіте. Сгукіаі Керогш 9 
поддерживает дополнительные типы переменных, которые не могут быть 
возвращаемым значением формулы, это диапазон (гап§е) и массив (аггау). 

Синтаксис Сгузіаі нечувствителен к регистру. Так, служебные слова ТЬеп, 
Ійеп и ТНЕ1М эквивалентны- Это правило не относится к тексту, заключен¬ 
ному в двойные кавычки. Использование формул имеет следующие ограни¬ 
чения: 

□ максимальное число выполнения цикла не может превышать 30000; 

□ размер строки (константы, строковой переменной, возвращаемого значе¬ 
ния функции) не может превышать 64К; 

□ размерность массива не может превышать 1000; 

□ текст формулы не может превышать 64К; 

□ максимальное число аргументов функций для функций с переменным 
числом аргументов, например СКоозе, не должно превышать 1000; 

□ год даты должен находиться в диапазоне 1—9999. 

Ниже приведены простейшие формулы, содержащие поля базы данных. 

Первая формула вычисляет количество дней, прошедших от заказа до от¬ 
грузки товара. Поле типа Оаіе — Огс1ег$. Огсіег Оаіе содержит дату заказа, 
поле Огбег5,8Ыр Оаіе — дату отгрузки товара. Формула возвращает целое 
число. 

//А Еогтиіа ОіаЦ изез сіаЬаЬазе ^іеісіз 
{Огсіегз .ЗЫр ЦаЬе} - {Огсіегз .Огсіег ЦаЬе) 
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Вторая формула возвращает стоимость заказа, которая равна произведению 
цены за единицу товара на количество. 

{ОгДегз ЦеЪаіІ.Шіі: Ргісе} * {Огйегз ВеЬаіІ.ОиапЬіЬу) 

Выражением (Ехргеззіоп) называется любая комбинация операторов, ключе¬ 
вых слов, функций и констант, возвращающих значение определенного ти¬ 
па, например, 

2+2; 

возвращает число 4, а 

"Иван "+"Иванов"; 

возвращает строку "Иван Иванов". 

Формула может содержать несколько выражений. В этом случае каждое вы¬ 
ражение должно заканчиваться символом /. Формула возвращает значение 
последнего выражения. 


5.3. Функции 

Сгузіаі Керогй 9 содержит более ста встроенных функций. Рассмотрим неко¬ 
торые из них. 

5.3.1. Функции работы с текстом (Зігіпд) 

Текст, поле типа Ыгіп§ или текстовая переменная в формуле может воспри¬ 
ниматься как массив, поэтому для выделения символа или последовательно¬ 
сти символов необходимо использовать индекс. Так, формула 
"Иванов"[3] 

вернет значение а — третий символ слева, а формула 
"Иванов" [-2] 

вернет значение о — второй символ справа. Формула 
{сизЪатег. :Еах} [1 Ъо 3] 

вернет три символа поля {сшІотег.Гах} с первого по третий. 

Для выделения отдельного символа или подстроки может также использо¬ 
ваться функция МісІ(5Тг, Зіагі, ЬепіК), где Ыг — строка, 5іаЛ — первая пози¬ 
ция выделяемой подстроки, ЬепіЬ — длина выделяемой подстроки. Функция 
МіД(сиз(;оіпег . Еах}, 1, 3) 

также вернет первые три символа поля {сизІотег.Гах}. 

Функция Тгіт(5і:гіп§) удаляет пробелы в строке, функция ТгітКіёіЬ(йгіпё) 
удаляет только пробелы справа, ТгітЬеЙ(Ыгіп§) — слева. Предположим, 
в полях таблицы СиЫотег содержатся следующие значения: ТШе — "Проф.”, 
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Сотасі Ріг5і Кате — "Иван", Сопіасі 1_а$1: Кате — "Иванов". Тогда 
формула 

ТгітКідГіС ({СизСотег .СопСасС ТіС1е})+ п " 

+ ТгітКідГіС ({СизСотег.СопСасС РігзС Цате}) +* " 

+ {СизСотег.СопСасС ЬазС Цате} 

вернет значение "Проф. Иван Иванов". 

Функция ТоТехКпитЬег, <1ес_рІасе,”іЬои2апд $ерагаіог", "сіесітаі Берагаіог”) 
конвертирует число в текст. Здесь іштЬег — число, <3ес_р1асе — количество 
знаков после запятой, Шоигапб зерагаіог — разделитель тысяч, сіесітаі $ера- 
гагог — разделитель дробной части. Три последних аргумента могут быть 
опущены. Например, если значение поля {Р1} равно 3.1415926, то функция 

ТоТехС({ РІ }, 4) 

вернет значение 3.1415. 

Функция То\Ѵогб$(питЬег, <1ес_р1асе) возвращает сумму прописью числа 
пшпЬег на английском языке. Здесь <3ес_р1асе — количество знаков после 
запятой. Так, функция 

ТоИогйз(3635.235, 4) 

вернет значение 'Чйгее Пюшапб §іх йипдгеб ФіЛу-Гіѵе апб 2350/10000". 

Для получения числа прописью на русском языке можно использовать 
функции из библиотек ІІРЬ (разд. 5.5). 

В старых информационных системах строковые данные часто хранились 
в верхнем регистре, например, "ИВАНОВ”. Чтобы в отчете получить 
"Иванов", можно использовать функции перевода текста в нижний ре¬ 
гистр — ЬохѵегСазе или верхний регистр — ІіррегСа$е, а также функцию оп¬ 
ределения длины строки Ьеп§іЬ. Так, если в поле {Сивіотег-Сотасі Рігзі 
Кате} хранится значение "ИВАНОВ", то формула 

ЦррегСазе({СизСотег.СопСасС РігзС Цате} [1]) + ЬомегСазе 
( {СизСсніег.СапСасС РігзС Ыате} [2 Со ЬепдСѢ ({СизСстег.СопСасС РігзС Цате}) ] ) 

вернет значение "Иванов". 

Функция КерІісаГеЗггіпаС'зІгіпа", п) повторяет значение строки 5Ггіп§ п раз. 
Например, функция 
КеріісаСеЗСгіпд {"*", 5 ) 

вернет значение *****. 

5.3.2. Арифметические функции (МаіІі) 

Набор арифметических функций включает тригонометрические функции 
(Зіп, Со5, Тап, Аіп), экспоненту (Ехр) и логарифм (Ію§), функцию отбрасы¬ 
вания дробной части (Тгапсаіе), функцию-генератор случайных чисел (Клб) 
и некоторые другие. 
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5.3.3. Агрегатные функции (Зиттагу) 

В Сгузіаі КероПз 9 богатый набор агрегатных функций (группа Зиттагу 
в списке функций). Каждая агрегатная функция имеет три или более вари¬ 
анта — с одним, двумя и тремя аргументами. Функция с одним аргументом 
производит подсчет значений по всему отчету. Например, функция 

СоипЬ ({СизЪотег.СизЪотег Цате}) 

возвращает количество клиентов по всему отчету. 

Функция с двумя аргументами производит подсчет в группе. В качестве вто¬ 
рого аргумента должно использоваться поле, по которому в отчете уже про¬ 
изведено группирование. Например, функция 

СоипЬ ({СизЬэтег.СизЬэтег Цате}, {СизЬотег .СоипЬгу} ) 

возвращает количество клиентов в стране, в отчете должна быть группиров¬ 
ка по полю Сшіотег.Соипігу. 

Третий аргумент используется в агрегатных функциях, если группирование 
производится по дате или логическому полю (Вооіеап). Если данные груп¬ 
пируются по дате, то должен быть указан период, по которому производится 
группировка, например по месяцам, по неделям, по дням и т. д. Тот же при¬ 
знак должен быть указан в качестве третьего параметра агрегатной функции 

СоипС({0гдегз.0гдег Атоипе}, {Огдегз.Огбег ШЬе), "топіЩІу" ). 

Эта функция вернет количество заказов в каждом месяце. В отчете должна 
быть группировка по полю Огбегз.Огбег Эаіе по месяцам. 

Аргументом агрегатной функции может быть массив. Так, функция 
5ит( [100,75,50]) 

вернет значение 225. 


Упражнение 5.1 

Используя в качестве источника данных таблицу СиЫотег, создайте отчет и 
включите поля СизІотег.Еазі: Уеаг'з Заіез и Сшіотег.Сизіотег №те. Соз¬ 
дайте группировку по городам (Сиыотег.Спу). Вставьте сумму по каждому 
городу, для этого: 

1. Создайте формулу {@ СйуОгоирЗит}, содержащую функцию Зит 
({СизЮтег.ЬаЫ Уеаг’з Заіез}, {Сшіотег.Сііу}). 

2. Вставьте ее в секцию Сгоир Рооіег. 

3. В секцию Оеіаііз вставьте формулу, рассчитывающую процент продаж 
клиента относительно общего объема Продаж в городе. 

4. {СиЫотег.Еазі Уеаг’з Заіев} % {@С ііу ОгоирЗит}. 
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5. Добавьте в отчет группировку по стране (СшЮтег.СоипІгу). В подвал 
(секция Огоир Рооіег) группы по стране добавьте формулу, подсчиты¬ 
вающую количество клиентов в каждой стране: 

"Количество клиентов в стране " + [СизРотег. СоипРгу} 

ТоТехР(ЦІ5РіпсРСоипР({СизРотег.СизРотег Ыате), {СизРотег.СоипРгу}) , 0) 


5.3.4. Функции для работы с датами 
и временем (Оаіе/Тіте) 

Функции, объединенные в группу Оаіе/Тіте, позволяют конвертировать и 
обрабатывать поля и переменные типа дата. Результат операций с такими 
полями зависит от типа операции. Так, формула 

{Огйегз.ЗМр Баре} - {ОгДегз .ОгДег ЦаРе) 

возвращает число, равное количеству дней от дня заказа — поле типа дата 
ОпЗегз. Огбег Оаіе — до дня отгрузки — Огбеіъ.Вйір Оаіе. 

Функции Ѵеаг({Ог<іег§.Ог<іег Оаіе}), Мотй({Огбег$.Огбег Оаіе}), 
0ау({0гбег8.0гбег Оаіе}) возвращают число — год, месяц и число даты заказа 
соответственно. Функция ОауОГѴѴеек({Огсіег$.51іір Оаіе}) возвращает номер 
дня недели (по умолчанию первым днем недели считается воскресенье) и мо¬ 
жет быть использована в формуле, возвращающей день недели прописью: 
["Воскресенье","Понедельник", 

"Вторник","Среда","Четверг","Пятница","Суббота"] 

[ЦауОШеек ({ОгДегз. ЗПір Царе}) ] 

В этой формуле в первых квадратных скобках задается массив строк 
(["Воскресенье","Понедельник"]). Во вторых квадратных скобках вычисляет¬ 
ся индекс массива. Формула возвращает строку элемент массива, соответст¬ 
вующую вычисленному индексу. Аналогично, с использованием функции 
МопІй(), можно написать формулу, возвращающую месяц прописью. 

Функция Оаіе(УУУУ, ММ, БО) имеет три числовых аргумента — год, месяц 
и день и возвращает дату. Эту функцию можно использовать для конверта¬ 
ции строки в дату при нестандартном формате хранения даты, например, 
ѴУУУ/ММ/ОО: 

Царе(ТоЫитЬег( {БРгіпдЦаРе} )[1 Ро 4], ТоИитЬег((ЗРгхпдЦаРе))[6 Ро 7], 
ТоИитЬег( {БРгіпдЦаРе} )[9 Ро 10]) 

Функция ОаіеТітеѴаІие возвращает дату-время и аналогична Оаіе. Эта 
функция может быть использована для конвертации значения строки или 
числа в дату. Допустимые значения аргументов ОаіеТітеѴаІие приведены 
в табл. 3.1. 
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Таблица 5.3. Допустимые значения аргументов функции ОаІеТітеѴаІие 

Функция Описание аргумента 

ОаІеТітеѴаІие йаіе — значения типа дата 

(сіаіе) 

ОаІеТітеѴаІие йаіе — значения типа дата , Ііте — значения типа время 
(сіаіе, Ііте) 

ОаІеТітеѴаІие ЫитЬег— количество дней от 30 декабря 1899 года, например, 
(питЬег) ОаІеТітеѴаІие(20) вернет дату 19 января 1900 года 

ОаІеТітеѴаІие Зігіпд — строка, представляющая дату и время, например 
(зігіпд) "ЗерІетЬег 15, 2002, 10:45а.т." 

ОаІеТітеѴаІие уеаг— год, например: 1996 

(уеаг, топІИ, сіау) т опІіі — месяц, например 1 соответствует январю 
сіау — день месяца 

ОаІеТітеѴаІие уеаг — год, например: 1996 

(уеаг, топІИ, сіау, тоП {^ _ месяц, например 1 соответствует январю 
гіоиг, тіп, зес) 

сіау — день месяца 
Ноиг— часы 
тіп — минуты 

зес — число, представляющее секунды 

5.3.5. Дополнительные функции 
(Асісііііопаі Рипсііопз) 

В разделе дополнительных функций (АсШіопаІ Рипсііопз) содержатся 
функции преобразования дат: ОТ5ТоОаіеТіте({сіаіеіітезігіп§}), 

ІЗТ5ТоОаіеТіте({сіаіеііте5ігіп§}) и ОТ5ТоТіте({сіаіеіітезігіп§})- Эти функ¬ 
ции ■ предназначены для конвертации строки в дату или дату-время. Так, 
функция 

ОТЗТоШСеТіте ("2000/01/13 11:30:15") 

вернет значение типа дата-время 2000/01/13 11:30:15. 

Функция ОаіеТітеТоОаІефаіеТіте) конвертирует поле типа дата-время 
в дату, ОаіеТітеТо5есоп<і(ОаіеТіте) возвращает количество секунд после 
полуночи, а ОаіеТітеТоТіте(ОаІеТіте) — время в "военном" формате 
00 : 00 : 00 . 

Дополнительные функции содержатся в библиотеках функций, определяе¬ 
мых пользователем (ІІРЬ). В списке функций окна Роппиіа Есіііог они 
сгруппированы по библиотекам. В наименовании каждой группы указывает¬ 
ся наименование файла библиотеки в формате и2*.сШ (разд. 5.5). 
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5.3.6. Функции периода времени (Эаіе Оапдез) 

Функции периода времени (Оаіе Напрев) не имеют аргументов и возвра¬ 
щают диапазон дат, который может быть использован для сравнения. 
В табл. 5.4 приведены периоды времени, возвращаемые этими функциями. 

Таблица 5.4. Функции периода времени 


Функция 


Описание 


АдесЮТоЗСЮауз Все дни с сегодняшнего и до 30 дня тому назад 

АдесіЗІТобСЮауз То же с 31 по 60 день 

АдесібІТоЭСЮауз То же с 61 по 90 день 

Оѵег9(Юауз Более 90 дней тому назад 

АІЮаІезРготТосіау Все будущие дни после сегодняшнего 

АІЮаІезРготТотоггоѵѵ Все будущие дни после завтрашнего 

АІЮаІезТоТосІау Все дни, предшествующие сегодняшнему 

АІЮаІезТоѴезіегбау Все дни, предшествующие вчерашнему 

Саіепбагі зіНаК Все дни первой половины календарного года 

СаІепбаг2пбНаІ[ Все дни второй половины календарного года 

Саіепбагі зЮІг 1 квартал 

СаІепбаг2псЮ1г 2 квартал 

СаІепсіагЗгсКЭІг 3 квартал 

СаІепсіаг41йСИг 4 квартал 

І_аз14ѴѴеекзТоЗип 4 недели, предшествующие последнему воскресенью. 

Начинаются в понедельник и кончаются в воскресенье. 
Например, если сегодня воскресенье, то период исчис¬ 
ляется с понедельника, бывшего четыре недели назад, 
по сей день включительно. 

Если сегодня 22 сентября 1996 года, 1_аз14\Л/еекзТо8ип 
начинается 26 августа (понедельник) и кончается сего¬ 
дня, 22 сентября (воскресенье). 

Если сегодня 28 сентября 1996 года, то 
І_а5І4ѴѴеекзТоЗил начинается 26 августа (понедельник) 
и кончается 22 сентября (предыдущее воскресенье). 

Последние семь дней, предшествующие сегодняшнему 

С первого по последний день предыдущего месяца 

С воскресенья по субботу прошлой недели 


І_аз170ауз 

І_азіРиІІМоп1Н 

І_азіРиІІѴѴеек 


І_азіѴеагМТ0 


Все дни текущего месяца прошлого года 
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Таблица 5.4 (окончание) 

Функция 

Описание 



1_аз(УеагУТ0 Все дни прошлого года, вплоть до текущей даты про¬ 


шлого года 

МопіНТоОаІе С первого дня месяца по сегодняшний день 

Ыехі...0ауз Даты за период, начинающийся с сегодняшнего дня 

ѴѴеекТоОаІеРготЗип С последнего воскресенья по сегодняшний день 

УеагТоОаІе С первого дня календарного года по сегодняшний день 

Диапазоны дат рассчитываются относительно даты печати, что соответствует 
специальному полю РгіпФаіе. По умолчанию в качестве даты печати берет¬ 
ся системная дата. Однако эту дату можно изменить в диалоговом окне 8еі 
Ргіпі Раіе аші Тіте (рис. 5.4), которое можно вызвать, выбрав пункт меню 

Керогі/8еі Ргіпі ГЗаІе апй Тіте. 



Рис. 5.4. Диалоговое окно Зеі Ргіпі Раіе апсі Тіте 
Упражнение 5.2 

Используя в качестве источника данных таблицу Оггіегв, создайте отчет и 
включите поля Огёег8.8Ьір Баіе и ОгіІегя.Опіег Аіпоилі. Подсчитайте отно¬ 
сительную долю заказов, отгруженных от текущего дня до 30 дней тому на¬ 
зад, от 31 до 60 дней тому назад, от 61 до 90 дней тому назад и более 
90 дней тому назад. Для этого в секцию ОеіаіІ8 внесите 4 формулы и скрой¬ 
те их. Для того чтобы скрыть формулу, необходимо щелкнуть по ней правой 
кнопкой мыши, в контекстном меню выполнить команду Рогтаі Ріеігі 
и в диалоге Рогтаі Егіііог включить опцию 5иррге88. 

1. 0 ю 30: 

ІЕ {Огдегз.ЗЬір ОаЬе) іп АдесЗОТоЗОШуз Ыіеп {ОгсЗегз. ОгсЗег АтоипС} еізе 0; 
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2. 31 іо 60: 

ІЕ {Огсіегз . ЗЬір ШЪе} іп АдесіЗІТобОШуз (Щеп {Огсіегз . ОгсЗег АшоипЬ} еізе 0; 

3. 6По 90: 

И {Огсіегз . ЗШр ШСе} іп Адедб1То90Шуз Ыіеп {ОгсЗегз.Огйег АшоипЬ) еізе 0; 

4. 90 Р1и§: 

Іі {Огсіегз .ЗЬір ОаЬе) іп 0ѵег9СЮауз Йіеп {ОгсЗегз .ОгсЗег АшоипЬ) еізе 0. 

В секцию Керогі РооГег включите следующие формулы. 

1. Тогаі Гог КерогГ — вычисляет общее количество заказов: 

Бит ({@0 Ьо 30})+3ит ({@31 Ьо 60})+5ит ({@61 Ъо 90})+8ит ({@90 Ріиз}); 

2. РегсепІ 0 Го 30 — вычисляет относительную долю заказов, отгруженных 
от текущего дня до 30 дней тому назад: 

Зит ({@0 Ьо 30}) % {ѲТоГсаІ іог КерогЬ); 

3. РегсепГ 31 Го 60 — вычисляет относительную долю заказов, отгруженных 
от 31 до 60 дней тому назад: 

Зит ({@31 Ъо 60}) % {ѲТоГсаІ іог КерогЬ} ; 

4. РегсепГ 61 Го 90 — вычисляет относительную долю заказов, отгруженных 
от 61 до 90 дней тому назад: 

Зит ({@61 Ьо 90}) % {ѲТоГсаІ іог КерогГ:}; 

5. РегсепГ 90 Р1и$ — вычисляет относительную долю заказов, отгруженных 
более 90 дней тому назад: 

Зит ({@90 Ріиз}) % {@Тоіа1 іог Керогі} . 

Измените дату отчета на 1.01.2001 и посмотрите результат на последней 
странице отчета. 

5.3.7. Функции состояния печати Ргіпі Зіаіе 

В разделе РгіпГ Згаге содержится ряд полезных функций, позволяющих 
управлять печатью отчета. Функция ОпРігкГРіеШ возвращает булево значение 
"истина", если строка печатается впервые. Функция ОпЬаЫ Кесогбх возвра¬ 
щает значение "истина", если печатается последняя строка отчета. Функция 
ІпКереаГебСгоирНеабег возвращает значение "истина", если заголовок груп¬ 
пы печатается не впервые. Функции N6x1(11(1) и Ргеѵіоб(ПсІ) возвращают зна¬ 
чение поля Пс1 из предыдущей и последующей строк соответственно. Функ¬ 
ции ЫМиІІ(ПсІ), №хГІ5ІМи11(ПсІ), РгеѵіобІбЫиІЦПсІ) возвращают значение 
"истина", если значение поля 1М текущей, последующей или предыдущей 
строки соответственно принимает значение N111,1.. 

Функция Ра§е№тЪег возвращает номер страницы, ТогаІРа§еСоипГ — общее 
количество страниц в отчете, функция Ра§е№ЛѴ1 — строку 

Ра§е N о/ М, 

где N — номер текущей страницы, М — общее количество страниц в отчете. 
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5.3.8. Функции свойств документа 
(Роситепі Ргорегііез) 

Функции свойств документа (Ооситет Ргореліез) возвращают значения 
свойств отчета: 

□ дату и время печати отчета — РгіпШаіе и РгітТіте; 

□ дату и время последнего изменения отчета — МосПГісанопОаге и 
МобіГісаііопТіте; 

□ дату и время последнего обновления данных отчета — ОагаОаге и 
ОаіаТіше; 

□ заголовок и комментарий к отчету — КероііТіЦе и ВероііСоттегЛз; 

□ наименование, дату создания и имя автора файла отчета — Рііепаше, 
РіІеСгеайопОаіе, РіІеАиіНог. 


5.3.9. Функции времени выполнения 
(Еѵаіиаііоп Тіте) 

Сгузіаі Керогіз 9 является многопроходным генератором отчетов, другими 
словами, он генерирует отчет в несколько этапов. На каждом этапе выпол¬ 
няются вычисления по формулам определенного типа. Существует пять эта¬ 
пов выполнения отчета. 

Предварительный первый этап — Веі'огеКеасііп§Кесог(І8. На этом этапе про¬ 
изводятся вычисления по формулам, не содержащим специальные поля, по¬ 
ля базы данных или суммирующие поля, например формула 2*2. 

Основной первый этап — \ѴЫ1еКеас1іп§К.есог<35. Выполняется чтение полей 
из базы данных, вычисление по формулам, содержащим поля базы данных, 
вычисление по формулам выборки данных, сортировка, группировка, созда¬ 
ние матричных таблиц. 

Предварительный второй этап. Выполняется группирование Тор N и иерар¬ 
хическая группировка. 

Основной второй этап — \ѴЫ1еРгіпІіп§Кесогс!5. Выполняется вычисление по 
формулам, содержащим суммирующие поля и функции, поля гиппіп§ Іоіаіз, 
специальные поля типа номера страницы и функции состояния печати. 

Третий этап. Вычисляются формулы, содержащие специальные поля и 
функции, возвращающие общее количество строк в отчете (например, 
Тоіа1Ра§еСоипі или Ра§е1ч[оГМ). 
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Существует возможность переноса выполнения формулы на более поздний 
этап, но не на более ранний. Для этой цели Сгумаі Керогіз 9 содержит 
функции времени выполнения: 

ВеГогеКеасІіпёНесогсІз — указывает, что формула должна выполняться на 
этапе ВеГогеКеасііп§Кесогс1$, перед чтением данных; 

\ѴНіІеКеасііп@Кесогс1х — указывает, что формула должна выполняться на эта¬ 
пе МЬі1еКеас1іп§КесогсІ5, во время чтения данных; 

\ѴЬі1еРгіпПп§КесогсІ8 — указывает, что формула должна выполняться на эта¬ 
пе ѴДнІеРгіпнпёКесогсІк, во время печати; 

Еѵа1иаіеАйег({@Гогти1а}) — указывает, что формула должна выполняться 
после выполнения формулы, указанной в качестве аргумента {@Гогши1а}, 
например, Еѵа1иаіеАйег({@8еіѴагіаЫе}). 

5.3.10. Функции работы с массивами 

Сгукіаі Керогід 9 имеет набор функций обработки массивов и поддерживает 
динамические массивы. Функция МакеАггауО позволяет задать значения 
массива. С той же целью можно использовать квадратные скобки. Так, вы¬ 
ражения, определяющие переменные типа массив 

зЪгіпдѴаг аггау х: = МакеАггау ("а", "ЬЬ", "ссс") ; 

И 

зЬгіпдѴаг аггау х: = ["а", "ЬЬ", "ссс"] ; 

эквивалентны. 

Для применения динамических массивов можно использовать функции 
Кесііт и Кесііт Ргезегѵе. 

Функция Кесііт — переопределяет размеры массива с потерей всех предваритель¬ 
но определенных значений, например, после выполнения следующей формулы 
зЪгіпдѴаг аггау х:= МакеАггау {"а", ''ЬЬ' 1 , "ссс”) ; 

КесЗіт х [ 4 ] ; 
х[4] = "«Мей" 

значения массива х будут равны "сШскІ"), а после выполнения 

зЪгіпдѴаг аггау х: = МакеАггау ("а", "ЬЬ”, "ссс") ; 

КеЛіш Ргезегѵе х[4] ; 
х[4] = "сИсИ" 

массив х примет значения ("а”, "ЬЬ”, "ссс”, "<ЗсШ"). 

Функция Іі Войпб(Аггау) возвращает размер массива. Например, формула 

Ьосаі ШтЬегѴаг Аггау зітрІеАггау; 

Кесііт зітрІеАггау [10]; 

ЦВоипЦ(зітрІеАггау) 
возвращает значение 10. 
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5.3.11. Специальные функции 
(Сиеіот Іипсііопз) 

Специальные функции представляют собой создаваемые разработчиком 
процедуры, возвращающие значение. Однажды созданная специальная 
функция может многократно использоваться как в отчете, в котором она 
создана, так и в других отчетах, если она помещена в хранилище. Использо¬ 
вание специальных функций позволяет поддерживать единую логику при 
разработке всех отчетов в рамках компании. 

Специальные функции могут быть созданы как в синтаксисе Сіузіаі, так и 
Ва$іс. Специальная функция сначала должна быть создана в среде Сизіот 
Рипсііоп Еііііог, а затем включена в формулу с помощью Рогтиіа Ехрегі. От¬ 
метим, что инструменты создания и использования специальных функций 
входят во все варианты поставки Сгузіа! Керопх 9, кроме варианта Зіапбагб. 

Для создания специальной функции необходимо в диалоговом окне Рогтиіа 
\Ѵогкя1юр раскрыть список создания нового объекта (табл. 5.1) и выбрать 
пункт СияЮш Рипсііоп. Появляется диалоговое окно Сияіот Рипсііоп Кате 
(рис. 5.5). 


Сизіолі Рипсііоп Ноте 


Ы&тея | СиямпРипсЙопЕкатрІе 

, ,.С, ; -'' • ■ 

:Ц$е Ех'гасісч ] Ц$е Едііог . | ' СапсеІ 


Рис. 5.5. Диалоговое окно Сизіот Рипсііоп N30)6 

В диалоговом окне Сияіот Рипсііоп Кате следует ввести имя специальной 
функции. Для создания функции на основе существующей формулы следует 
щелкнуть на кнопке ІІзе Ехігасіог, для создания функции "с нуля” — на 
кнопке ІІяе Еёііог. Кнопка ІІяе Еііііог вызывает окно Сияіопі Рипсііоп Еііііог, 
интерфейс которого подобен окну Рогтиіа Еііііог (разд. 5.1), однако в отли¬ 
чие от него не имеет списка объектов отчета, поскольку синтаксис специ¬ 
альных функций запрещает использование объектов отчета в качестве фор¬ 
мальных аргументов. 

Создание специальной функции в среде Сияіопі Рипсііоп Еііііог (рис. 5.6) не 
отличается от создания формулы в Рогтиіа Еііііог. Двойной щелчок на спи¬ 
ске операторов или формул включает оператор или формулу в текст специ¬ 
альной функции, который показывается в нижнем окне. 

Специальная функция должна начинаться служебным словом Рипсііоп, со¬ 
держать список аргументов и исполняемый код, например 

РипсЬіоп ШитЬегѴаг ѵаІиеТоІпсгеазе, пшпЬегѴаг регсепЫпсгеазе) 
ѵаІиеТоІпсгеазе + ѵаІиеТоІпсгеазе * регсепЫпсгеазе / 100; 
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Рис. 5.6. Диалоговое окно Сивіот Рипсііоп ЕсІИог 


Здесь "ИитЬегѴаг ѵаІиеТоІпсгеазе, питЬегѴаг регсепііпсгеахе" — список ар¬ 
гументов, ”ѵа1иеТоІпсгеа$е 4- ѵаІиеТоІпсгеазе * регсепііпсгеаке / 100;" — ис¬ 
полняемый код. Исполняемый код может быть заключен в круглые скобки. 

Список аргументов разделяется запятой, допускается пустой список. Слу¬ 
жебное слово Орііопаі означает, что при вызове функции аргумент может 
быть опущен. Для аргументов, описанных как Орііопаі, требуется задание 
значения по умолчанию, например 

ОрГіопаІ ШтЬегѴаг Х :=0 

Допускается использование аргументов следующих типов: 

□ ІЧитЬегѴаг — число; 

□ СиггепсуѴаг — валюта; 

□ ВооІеапѴаг — логический (Вооіеап); 

□ ОаіеѴаг — дата; 

□ ОаіеТішеѴаг — дата-время; 

□ ТішеѴаг — время; 

□ 5ігіп§Ѵаг — строка. 

Возможно использование в качестве аргументов массивов и диапазонов, 
кроме диапазона типа Вооіеап. 

Исполняемый код должен вычислять возвращаемое значение функции. 
Синтаксис специальных функций накладывает следующие ограничения на 
исполняемый код: 

□ нельзя использовать поля отчета, включая агрегатные, и поля базы данных; 

□ допускается использование только локальных переменных, т. е. нельзя 
использовать переменные, описанные как ике ьКагеб или §1оЬа1; 
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□ запрещается использование рекурсии; 

□ запрещается использование библиотек ІІРЬ (разд. 5.4)\ 

□ запрещается использование функций времени выполнения (Еѵаіиаііоп 
Тіше), функций состояния печати (РгіпТ Зше), функций свойств доку¬ 
мента (ОосишеШ РгореЛіез), а также функций Клб, СиггепіРіеІсГѴаІие, 
ОеГаиІіЛигіЬше и ОгібКоѵѵСоІитпѴаІие. 

После создания специальной функции следует определить ее свойства. Для 
этого необходимо щелкнуть на кнопке, осуществляющей переключение ме¬ 
жду окнами Сивіога Рипсііоп ЕіШог и Сизіот Рипсйоп Ргорегііев (табл. 5.1), и 
в окне СікТот Рипсйоп Ргорегііез (рис. 5.7) внести описание (Зшшпагу), ка¬ 
тегорию (Саіе§огу) и автора (АиЙюг) специальной функции. Наименование 
категории будет использовано как папка в древовидном списке Рогтиіа 
ѴѴогклЬор в разделе специальных функций. 



[Си^отГипсйопЕ хаспріе 


Пример специальной Функции Увеличивает значение первого аргумента. Второй аргумент • величина увеличения 
значения первого в процентах, например 
Си$*стРипс1іопЕ хетрІе(200.50) 
возвращает значение 300 


[Пример специальной Функции. 


Маклаков 


[ЫитЬег. 


ГчѵУѵл?:,гл 


ѵаіиеТ Ыпсгеаье ЫитЬег 

ретсеіНІпсгаазе ФіигоЬег 


Рис. 5.7. Окно СивТот Рипсііоп РгорегТіеа 


Нередактируемое поле Керояііогу показывает наименование хранилища, 
в которое помещена функция. В поле Ѵегяоп отображается автоматически 
генерируемый номер версии функции. Номер версии обновляется каждый 
раз при обновлении специальной функции в хранилище. Поле Кеіигп Туре 
показывает тип возвращаемого значения и зависит от типа аргументов. 

В списке Аг§шпеп($ для каждого аргумента можно задать описание и значе¬ 
ние по умолчанию. 
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Новую специальную функцию можно создать на основе существующей 
формулы. Для этого в диалоговом окне Си$*от Рипсйоп N8016 следует щелк¬ 
нуть на кнопке Иве Ех*гас*ог. Появляется диалоговое окно Ехігас* Сихіош 
Рипсііоп Ггот Рогтиіа (рис. 5.8). 



Рис. 5.8. Диалоговое окно Ехігасі Сизіот Рипсііоп *гот Рогтиіа 


В поле Рогтиіа Тех* отображается текст формулы, на основе которой будет 
создана специальная функция. Поля отчета и базы данных заменяются ар¬ 
гументами. Тип аргумента соответствует типу поля отчета, имя аргумента по 
умолчанию генерируется как ѵІМ, где N — порядковый номер, например 
ѵ1,ѵ2 ѵЗ и т. д. Например, на основе формулы 
{СизЪотег.ЬазГ Уеаг'з За1ез}%{@СіСуСгоир8ит} 
будет создана специальная функция 

РипсЬіоп (сиггепсуѴаг ѵі, сиггепсуѴаг ѵ2) 
ѵ1%ѵ2 

В полях Си8*0т Рипс*іоп Nате и Зиттагу можно задать имя и описание 
специальной функции. 

Для размещения специальной функции в хранилище необходимо щелкнуть 
по кнопке перемещения функции в хранилище в палитре инструментов 
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Рогшиіа \ѴогЫіор (табл. 5.1). Открывается диалоговое окно Орепв Яіе Айй 
Сикіога Гипсііоп Іо Керовііогу, в котором следует щелкнуть на кнопке ОК. 

Для включения специальной функции в отчет из хранилища следует пере¬ 
местить указатель на соответствующую строку в древовидном списке 
Рогшиіа \Ѵогк8Іюр и щелкнуть на кнопке внесения функции в отчет 
(табл. 5.1). 

После включения специальной функции в отчет она появляется в списке 
функций Рогшиіа Еёііог в разделе Сивіош Рипсгіоп8 и ее можно использовать 
при создании формул так же, как и встроенные функции Сгуті КероЛк 9. 


5.4. Библиотеки функций, определяемых 
пользователем (Орі_) 

Функции, определяемые пользователем (ІІРЬ), по назначению подобны 
специальным функциям, однако в отличие от них создаются во внешних 
средах программирования — С++, ОеІрЬі и Ѵізиаі Вазіс. Код библиотеки 
функций ІІРЬ должен быть откомпилирован в динамическую библиотеку, 
файл библиотеки должен быть размещен в корневом каталоге СгуШІ 
Кероііз 9, например 

С:\ Рго§гат Рі1е5\Сгу5іа1 ОесІ5Іоп5\Сгу$ті КерогШ 9. 

Имя файла библиотеки должно начинаться с символов и21, например 
и21затр1е.сі11. 

Ріиже приведен фрагмент кода библиотеки на языке С++ , 

#іпс1ийе <ВДіпс1оѵз .Ь> 

#іпс1ийе "ОТПІІ.Гі" 

#іпс1исіе "ЦРМаіп.Ь" 

#іпс1ийе "ЩЩзег.Ь" 

#<Зе:Еіпе РісСигеР1асеПо1<Зег ’х' 

ЦРРипсСіопЛе^ЗСгіпдз РипсСіопОеСЗСгіпдз [] = 

{ 

{"ЗСгіпд РісСиге (ЗСгіпд, ЗСгіпд)", 

РісСиге}, 

{КЮЫ,, ШЫ,, ШЫЛ 
}; 

Код должен "подключать" модули ІІРОН.Ь, ІІРМаіп.Ь и ІІРІІзег.Іі, которые 
входят в поставку Сгузіаі КероіТз 9. 

РІовые функции появляются в списке функций в разделе Аббіііопаі 
Рипсілопз после перезапуска Сгузіаі Керогіз 9. 
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5.5. Переменные 

Использование переменных в формулах включает три стадии: 

1. Декларирование переменной. 

2. Присвоение значений. 

3. Использование для вычислений. 

При декларировании переменной запрещено использование в качестве име¬ 
ни зарезервированных слов и имен формул, нельзя также использовать име¬ 
на длиной более 256 символов. Переменная может быть объявлена как ло¬ 
кальная (Ьосаі), глобальная (СІоЬаІ) и разделяемая (ЗЬагеб). Локальная 
переменная сохраняет значение только в пределах формулы, в которой она 
определена. Глобальная переменная сохраняет значение в пределах отчета. 
Разделяемая переменная сохраняет значение в пределах отчета, включая 
подотчеты, создание отчетов с подотчетами будет описано в главе 6. При 
использовании переменной более чем в одной формуле, она должна быть 
декларирована в каждой из них как глобальная или разделяемая. По умол¬ 
чанию, если рамки применения переменной не указаны, она воспринимает¬ 
ся как глобальная. 

Операторы декларирования переменных находятся в нижней части списка 
операторов в правом окне редактора Рогшиіа ЕсЗііог. 

Поддерживаются несколько типов переменных. В первую группу типов вхо¬ 
дят те же типы, что и типы полей базы данных: 

□ ТЧитЬегѴаг — число; 

□ СиггепсуѴаг — валюта; 

□ ВооІеапѴаг — логический (Вооіеап); 

□ ГЗасеѴаг — дата; 

□ ОагеТішеѴаг — дата-время; 

□ ТітеѴаг —время; 

□ 5тп§Ѵаг — строка. 

Декларирование переменной может быть совмещено с присвоением значе¬ 
ний. В этом случае должен применяться оператор присваивания :=. В пра¬ 
вой части оператора присвоения может быть не только константа, но и 
арифметическое выражение. Ниже приведены четыре примера декларирова¬ 
ния переменной: 

ШтЪегѴаг АтоипЪ; 

ШтЪегѴаг ОиапСіСу :=5; 

СиггепсуѴаг ЗеІІРгісе: = {РгоДис1;.Ргісе} *1 .1; 

ВооІеапѴаг ОѵегОиоЬа := {Наіез} > (ОиоЬа);. 
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Во вторую группу входят переменные диапазона: 

□ ІЧитЬегѴаг гап§е — диапазон чисел; 

□ СиггепсуѴаг гап§е — диапазон валют; 

□ ОагеТітеѴаг гап§е — диапазон дат-времени; 

□ ОасеѴаг гап§е — диапазон дат; 

□ ТігпеѴаг гап§е — диапазон времени; 

□ 8ігіп§Ѵаг гап§е — диапазон строк. 

Переменные диапазона могут использоваться в операторах сравнения. Ниже 
приведен пример формулы, использующей переменную диапазона: 

ШтЪегѴаг Капде СК := 20 Іо 30; 

ІЕ {ОгсЗегз БеЬаИ .ШіЬ Ргісе} іп СК Оіеп 1 еізе 0. 

В третью группу входят массивы: 

□ ІЧитЬегѴаг аггау — массив чисел; 

□ СиггепсуѴаг аггау — массив валют; 

□ ОаіеТітеѴаг аггау — массив дат-времени; 

□ ОасеѴаг аггау — массив дат; 

□ ТітеѴаг аггау — массив времени; 

□ 8ігіп§Ѵаг аггау — массив строк. 

Примеры декларирования массива: 

НДгіпдѴаг аггау Меекдауз:= ["Воскресенье" ("Понедельник", ...] 

Ьосаі ИиіпЬегѴаг Аггау х := МакеАггау (1, 1000, 10, 100, 10); 

В последнюю группу входят массивы диапазона: 

□ ІЧитЬегѴаг гап§е аггау х:=[а іо с, у іо г ] — массив диапазона чисел; 

□ СиггепсуѴаг гап§е аггау — массив диапазона валют; 

□ ОаіеТішеѴаг гап§е аггау — массив диапазона дат-времени; 

□ ОаіеѴаг гап§е аггау — массив диапазона дат; 

□ ТітеѴаг гап§е аггау — массив диапазона времени; 

□ 8ігіп§Ѵаг гап§е аггау — массив диапазона строк. 

Пример декларирования массива диапазона: 

8ЬагесІ 8ігіпвѴаг Вапве Аггау у := ["А" То "С", "Н" То "Г]; 

Упражнение 5.3 

Вычисление кумулятивного (накапливающего) значения. 

Используя в качестве источника данных таблицу Огйегя, создайте новый 
отчет и включите поле Огёегз.Огёег Ашоипі. Создайте формулу, значение 
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которой равнялось бы сумме значений поля Огйегк.Огйег Атоипі из всех 
предыдущих строк. Для этого 

в секцию Керогі Неаііег поместите скрытую формулу Кекеі: 

сиггепсуѴаг Кѵаг : = 0; 
в секцию Оегаіік поместите формулу Бівріау: 

сиггепсуѴаг Кѵаг ; 

Кѵаг:= Кѵаг + {Огйегз .ОгсЗег АтоипЬ) 

Посмотрите результат. Отчет должен выглядеть примерно так: 


Огііег АтошЦ 

Оіхоіаѵ 

50$ 

50$ 

44$ 

93$ 

44$ 

137$ 

33$ 

170$ 

33$ 

203$ 

50$ 

252$ 

42$ 

294$ 

983$ 

1 277$ 

Обратите внимание на то, что по умолчанию отображаются целые значения 
сумм. Изменить формат отображения суммы можно в диалоговом окне 
Рогтаі Е(Шог, которое вызывается из контекстного меню. Выполните ко¬ 
манду меню Керогі | Кесогё 8ог1 Ехрегі и установите сортировку по полю 
Огйег$.Ог(іег ГО. После этого отчет будет выглядеть так: 

Оггіег Аіпоипі 

Эіхріаѵ 

3 480$ 

94 846$ 

3 480$ 

98 326$ 

29$ 

98 355$ 

2 447$ 

104 282$ 

150$ 

104 431$ 

178$ 

104 609$ 

3 545$ 

. 111 754$ 


Формула Оізріау больше не показывает кумулятивное значение. Это связа¬ 
но с тем, что вычисление формул Бівріау и Ке$еі происходит на более 
раннем этапе, чем сортировка данных. Чтобы формула Бізріау показы¬ 
вала правильный результат, необходимо добавить в формулы функцию 

ѴѴЬіІеРгіпйп^Кесогйв. 
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Формула Ке$еГ должна иметь следующий вид: 
ИЪіІеРгіпЬіпдКесогсіз ; 
сиггепсуѴаг Кѵаг := 0; 

а формула Оікріау 
ИЬіІеРгіпЪіпдКесогсіз ; 
сиггепсуѴаг Кѵаг; 

Кѵаг.- = Кѵаг + {Огсіегз .Огсіег АтоипС) 

После этого кумулятивное значение отображается корректно. 


5.6. Управляющие операторы 

Помимо операторов декларирования переменных, формулы Сгуыаі Керогік 9 
позволяют использовать операторы следующих типов: 

□ арифметические операторы: сложение, вычитание, умножение, деление 
и ДР-; 

□ операторы сравнения больше, меньше и др.; 

□ строковые операторы: конкатенация, выделение подстроки; 

□ операторы диапазонов: создание диапазона, проверка на вхождение 
в диапазон; 

□ булевы операторы: логические "и", "или" и др.; 

□ операторы работы с массивами: создание массива, изменение размерно¬ 
сти массива и др.; 

□ управляющие операторы: условия, цикла и др.; 

□ прочие операторы: присвоение, комментарий и др. 

Полный список операторов доступен в правом окне редактора Рогтиіа 
ЕёіГог. Для ввода оператора в текст формулы следует щелкнуть на нем дваж¬ 
ды. Рассмотрим более подробно управляющие операторы. 

Оператор ІГ Яіеп еке — условный оператор — позволяет выполнить фраг¬ 
мент кода в зависимости от условия. Формальный синтаксис условного опе¬ 
ратора 

ІГ X Яіеп У еіве 2, 

где X — логическое выражение, возвращающее значение "истина" или 
"ложь", У и Ъ — выражения, возвращающие значения одного типа, напри¬ 
мер, строковую или числовую константу. После еке может следовать другой 
оператор іГ Йіеп еіке. 




Использование формул 


113 


Упражнение 5.4 

Используя в качестве источника данных таблицу Сикіошег, создайте отчет 
и включите поля Сивіошег.Ьаві Ѵеаг’8 8а1ев и СикІошег.СикІошег ^те. 
Создайте формулу, возвращающую значение "Хорошо", если значение поля 
Сизіотег.ЬазІ: Ѵеаг'8 8а1е« больше 30000, и "Плохо", если значение поля 
Сивіотег.ЬавІ: Ѵеаг'8 8а1ев меньше 1000. Разместите ее в секции Ое(аіІ8. 

ІГ {СизСошег.ЬазС Уеаг'з 3а1ез}>3000 гЪеп " Хорошо " еізе ІГ 
(СизЬотег.ЬазГ Уеаг'з За1ез}<5000 ГЬеп " Плохо " 

В некоторых случаях функция ІІР(Х,Ѵ,2) может заменить оператор іГ Йіеп 
еіве. Первый аргумент функции X — логическое выражение, второй аргу¬ 
мент У — выражение, выполняющееся, если X возвращает значение 
"истина", и третий аргумент 2 — выражение, выполняющееся, если X воз¬ 
вращает значение "ложь". 

Упражнение 5.5 

Используя в качестве источника данных таблицу Сивіошег, создайте отчет и 
включите поля СивГотег.ЬавГ Ѵеаг'8 8а1е8, Си8іотег.Соиійгу и Сивіотег. 
Сивіотег №те. Необходимо подсчитать сумму продаж в прошлом году 
в Европе, Северной Америке и Южной Америке. Проблема заключается 
в том, что в базе данных нет признака континента. Один из способов расче¬ 
та суммы по признаку, который не хранится в базе данных, был рассмотрен 
в разд. 3.2 (специальная группировка). Ниже рассматривается другой спо¬ 
соб — без группировки, но с использованием формул. 

В секции Иеіаіів отчета разместите три формулы: 

1ЧА: 

ІГ {СизСотег .СоипСгу) іп ["СапаЦа","ЦЗА", "Мехісо" ] Ыіеп {СизСотег.ЬазГ 
Уеаг'з Заіез} еізе 0 

8А: 

ІГ {СизСотег.СоипГгу} іп 

[ "АгдепСіпа", "ВаПатаз" ,"ВагЬайоз","Вгагіі","Вегтисіа","Воііѵіа","СПіІе", 
"СоІотЪіа","Есиасіог","Рапата","Реги","Ѵепегиеіа"] 

Ыіеп {СизГошег.Баз Г Уеаг'з Заіез) еізе О 

ЕЙ: 

ІГ {СизСстег .СоипСгу) іп 

[ "АизГгіа", "Веідіит", "СгесП КериЫіс", "Цептагк”, 

"Епдіапсі","Ріпіапй","Ргапсе","Оегтапу","Сгеесе”,"Нипдагу", 

"ІгеІапЦ", "ЬихетЪоигд", "ЦеЫіегІапсІз", "ЦогНЬет ІгеІапсЗ”, 

"Цогѵау", "Роіапсі", "РогСидаІ", "Котапіа", "Киззіа", "ЗсоГІапсі", 

"Зраіп", "ЗадеЦеп" , "ЗадіСгегІапсі", "Маіез ”, "ІТкгаіпе" , "ІСаІу", "ЦК" ] 

ГЬеп {СизСотег.ЬазС Уеаг'з Заіез) еізе О 
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Создайте суммирующее по отчету поле (Сгапё Тоіаі) для каждой формулы 

8А, ЕИ 

В секции Керогі Еооіег появятся поля, показывающие общее количество 
продаж по каждому континенту. 

Оператор веіесі са«е подобен условному оператору, но позволяет записать 
сложные выражения в более компактной форме. Формальный синтаксис 
оператора веіесі саке следующий: 

ЗеІесЪ {поле}_сазе XI .- У1 
сазе Х2 : У2 

сЗе:Еаи11:: УЦ 

где {поле} — поле отчета, переменная или параметр, Хп — значения этого 
поля, Уп — выражения, возвращающие значения одного типа. Например, 
формула: 

Неіесі: {СизЬотег.Рах}[1 То 3] 

Сазе "604", "250" : 

"ВС" 

Сазе "206", "509", "360" : 

"ИА" 

Цеігаиіі: : 

возвращает значение ВС, если первые три цифры поля Сікіотег.Рах равны 
604 или 250, "\УА" — если 206, 509 или 360, и пустую строку во всех прочих 
случаях. 

Операторы цикла позволяют организовать вычисления в цикле. Сгузіаі 
Керогіз 9 содержит три оператора цикла: 

□ Гог Го «Гер ёо; 

□ лѵііііе ёо; 

□ ёо лѵііііе; 

и два оператора выхода из цикла: 

□ ехіГ Гог; 

□ ехй лѵііііе. 

Формальный синтаксис оператора Гог іо 8іер ёо: 

іог і :=Ц Со М зЬѳр К йо X 

где 

N — начальное значение счетчика цикла, 
м — конечное значение счетчика цикла, 
к — шаг счетчика цикла, 
х — операторы, выполняемые в цикле. 
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Ниже показана формула, обращающая строку так, что первый символ ста¬ 
новится последним, второй — предпоследним и т. д. 

//Обращение строки 
Ьосаі ЗбгіпдѴаг збг := 

Ьосаі ЫитЪегѴаг збгЬеп : = 

ЬепдбП ({Сизботег.Сиз ботег Цате}); 

Ьосаі ШтЬегѴаг і; 

Рог і := збгЬеп То 1 Збер -1 Бо 
( 

збг := збг + {Сизботег.Сизботег Цате) [і] 

) ; 
збг 

Оператор цикла \ѴЬИе имеет два варианта использования: 

□ \ѴЫ1е X Бо V; 

□ Бо V ѴИііІе X, 

где X — логическое условие, V — операторы, выполняемые в цикле. 

Операторы выхода из цикла ехй Гог и ехіі \ѵЬі!е могут входить в число опера¬ 
торов, выполняемых в цикле, и позволяют прекратить выполнение операто¬ 
ра цикла. 

Например, если массив N имеет четыре значения 

["Ргапк”, "Неіеп", "РгесГ, ’ЪіпсІа"], то следующая формула возвращает значе¬ 
ние 3. 

ЗбгіпдѴаг Аггау Ц; 

Ьосаі ЦитЬегѴаг і; 

Ьосаі ЦитЬегѴаг гезиіб := -1; 

Рог і :=1 бо 4 Во 
( 

Іб Ц[і] = "РгесГ ТЪеп 
(гезиіб := і; 

Ехіб Рог) 

) ; 

гезиіб 


5.7. Использование формулы 
для выборки данных 

Формулы Сгузіаі Керогй 9 могут быть использованы для вычислений, для 
выборки, форматирования объектов отчета по условию (разд. 6.1), а также 
для создания специальных сообщений АІегТз. 
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В главе 3 было показано, как с помощью редактора Зеіесі Ехрегі можно за¬ 
дать условия выборки. При этом Сгузіаі Керогіз 9 создает формулу, возвра¬ 
щающую логическое значение. Просмотреть текст формулы можно, щелк¬ 
нув по кнопке 8 Ьо\ѵ Рогшиіа в диалоговом окне Зеіесі Ехрегі (рис. 3.1). 
Формулы, созданные автоматически при помощи Зеіесі Ехрегі, имеют огра¬ 
ниченные возможности. В частности, если создается несколько условий вы¬ 
борки, то они объединяются логическим "и". Чтобы создать более сложные 
условия выборки, следует воспользоваться диалоговым окном Кесогё 
Зеіесііоп Рогшиіа Еёііог, которое можно вызвать из Зеіесі Ехрегі, последова¬ 
тельно щелкнув на кнопках ЗЬоіѵ Рогшиіа и Рогшиіа Еёііог. Интерфейс диа¬ 
логового окна Кесогё Зеіесііоп Рогшиіа Еёііог идентичен интерфейсу Рогшиіа 
Еёііог, рассмотренному ранее. Заметим, что если формула, созданная с по¬ 
мощью Кесогё Зеіесііоп Рогшиіа Еёііог, более сложна, чем та, которую мож¬ 
но получить с помощью Зеіесі Ехрегі (например, если формула содержит 
оператор "ОК"), то редактирование условий выборки на вкладках Зеіесі 
Ехрегі становится невозможным. 

С помощью Кесопі Зеіесііоп Рогшиіа Еёііог создаются формулы, которые 
применяются к каждой строке отчета. Однако, когда отчет содержит груп¬ 
пировку данных и вычисление агрегированных данных по группам, возни¬ 
кает необходимость отбора групп, например групп с наибольшим или наи¬ 
меньшим значением агрегированных данных, групп с определенным 
названием и т. д. Для такой выборки служит специальный инструмент — 
Сгоир Зеіесііоп Рогшиіа Еёііог. Для вызова Сгоир Зеіесііоп Рогшиіа Еёііог 
следует в диалоговом окне Зеіесі Ехрегі, щелкнув на кнопках 81ю\ѵ Рогшиіа, 
выбрать опцию Сгоир Зеіесііоп и затем щелкнуть на кнопке Рогшиіа Еёііог. 
Появляется окно Сгоир Зеіесііоп Рогшиіа Еёііог, и в нем в списке полей от¬ 
чета доступны имена групп и агрегатных полей (Зиттагу). 

Формулы для выборки данных не имеют имени. В каждом отчете может 
быть только одна формула для выборки записей и одна формула для выбор¬ 
ки групп. 

Отметим, что текст формул для выборки может быть размещен в отчете. Для 
этого следует включить в отчет специальные поля Кесогё Зеіесііоп Рогшиіа и 
Сгоир Зеіесііоп Рогшиіа. 

5.8. Специальные сообщения АІегіз 

Специальные сообщения АІегіз создаются разработчиком отчета для того, 
чтобы на этапе просмотра отчета при выполнении заранее заданного усло¬ 
вия возникало диалоговое окно с сообщением. Специальные сообщения 
могут быть полезны при обработке сложной информации, когда следует 
привлечь внимание пользователя к каким-либо необычным или важным 
фактам, например, когда поля или формулы принимают аномально большое 
или малое значение. Для специального сообщения необходимо создать 
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формулу, возвращающую значение "истина" или "ложь". Если при выполне¬ 
нии отчета на этапе \ѴЬНеРгіп1:іп|»КесопІ8 формула принимает значение 
"истина", возникает диалог с сообщением. Сообщением может быть текст 
или формула, т. е. сообщение может генерироваться динамически из текста 
и значений полей отчета. При выполнении отчета диалоговое окно с сооб¬ 
щением возникает столько раз, сколько раз формула принимает значение 
"истина". 

Для создания специального сообщения следует выполнить команду меню 
Керогі | АІегіз | Сгеаіе ог Мо<Шу АІегік. Появляется диалоговое окно Сгеаіе 
Аіегіз (рис. 5.9), в котором следует щелкнуть на кнопке Иеѵѵ. Для редактиро¬ 
вания уже существующего сообщения следует переместить указатель на 
строку в списке сообщений и щелкнуть на кнопке Е«М. 

Возникает диалоговое окно Егііі Аіегі (рис. 5.10). В поле №те следует задать 
имя специального сообщения, в поле Ме88а§е — текст, который будет ото¬ 
бражаться в диалоге при выполнении условия. 



Рис. 5.9. Диалоговое окно Сгеаіе АІеііз 



Рис. 5.10. Диалоговое окно ЕсЛІ АІегІ 
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Если текст сообщения должен генерироваться динамически, следует щелк¬ 
нуть на кнопке справа от поля Ме88а§е. Возникает диалоговое окно Еогтиіа 
ѴѴогкаЬор — Аіегі Ме$$а§е Рогтиіа Еёііог, в котором можно создать форму¬ 
лу, возвращающую текстовое сообщение, например, 

"Продажи компании "+{СизРотег.Сиз4;отег Ыате}+" в прошлом году превысили 
$100 000 и составили $”+ТоТехР ({СизРотег.ЬазС Уеаг’з 5а1ез},0 ) 

В формуле можно использовать функцию ОеГаиІіАигіЬиІе, которая будет 
принимать значение поля Ме88а§е диалогового окна Еёіі Аіегі. Например, 
если значение поля Ме$5а§е — "Продажи компании ", то формула 

ОеСаиІРАРРгіЬиРе +{СизРошег.СизРотег Цате}+” в прошлом году превысили 
$100 000 и составили $"+ТоТехР ({СизРотег.ЬазР Уеаг’з 5а1ез},0 ) 

будет возвращать то же значение, что и приведенная выше. 

Для создания условия специального сообщения следует щелкнуть на кнопке 
СогнШіоп Возникает диалоговое окно Рогпшіа \Ѵогк«Ьор — Аіегі СотШіоп 
Рогтиіа Еёііог, в котором следует создать формулу, возвращающую значение 
"истина" или "ложь", например, 

{СизРотег .ЬазР Уеаг'з За1ез}>100000 

Формула условия может включать поля отчета, суммирующие поля, но не 
должна содержать кумулятивных полей (гиппіп§ іоіаіз) и функций состояния 
печати. 

При переходе в режим просмотра отчета или при его обновлении в случае 
выполнения условия специального сообщения возникает диалоговое окно 
Керогі Аіегіз (рис. 5.11), в котором отображается текст сообщения. Щелчок 
на кнопке Ѵіе\ѵ Кесогйя устанавливает указатель на строку отчета, на кото¬ 
рой формула условия возвратила значение "истина". 


1 ШЗ Вероіі Аіеііз 
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"Продажи компании “Тек Віке$ в прошлом году превысили $100 000 и составили $301 568р. ; : 'Д : 
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Рис. 5.11. Диалоговое окно Керогі АІегіз 


Для принудительного вызова специального сообщения следует выполнить 
команду меню Керогі | АІегіз | Тгі^егегі АІегіз. 
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Для отмены просмотра сообщения при обновлении отчета надо выключить 
опцию Бізріау А1ег($ оп КеГге$Ь на вкладке Керог(іп§ диалогового окна 
Орііопз (команда меню РПе | Орйош). 

Сгузіаі К.ероп$ 9 содержит три функции для работы со специальными сооб¬ 
щениями: 

□ І$А1епЕпаЫеб("А1еііКате") 

□ І$А1елТгі§§егеб("А]еП:Кате" ) 

□ А1егіМе$$а§е(”А1еП:Нате" ) 

Аргументом этих функций является имя специального сообщения, заклю¬ 
ченное в двойные кавычки. Функция А1еП:Ме$$а§е("А1егі:№те") возвращает 
текст специального сообщения. Функция І§А1еПТгі§§егеб("А1еН:№те") воз¬ 
вращает значение "истина", когда выполняется условие специального сооб¬ 
щения. Функция 1$А1елЕпаЬ1ед("А1егН9ате") возвращает значение "истина" 
(іше), если в отчете существует специальное сообщение с именем 
АІеЛКате. 

Функции работы со специальными сообщениями показываются в разделе 
АІегіз списка функций окна Роггаиіа Е<Шог В этом же разделе содержится 
список имен специальных сообщений (рис. 5.12). 


I 


Шч^ЕѵаІиаІіоп Тіте 
Ргіпі Зіаіе 

Й Цф Роситепі Ргорегііез 
Е%А!ег(§ 

І •• ІзДЫЕпаЬІесІ (аІеДМате) 

• ІзАІегіТ ііддегесі (аІегМате) 

• • АІегіМеззаде (аІегІЫате) 

Э^АЫМате$ 

; 

ІзАЛегчгТгіддегесІ ("АІегРІ") ъЬе» АІег^Невзаде ("АІегРІ") 


Рис. 5.12. Раздел Аіегіз списка функций окна Рогтиіа Есіііог 


5.9. Использование параметров 
в формулах 

Параметры могут использоваться в формулах наряду с полями базы данных 
и специальными полями. Имя параметра начинается с символа ?, например 
?Ке§іоп. 

Параметры могут использоваться в формулах, применяющихся для вычис¬ 
лений, выборки и форматирования. 
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Так, формула, созданная с помощью Кесопі Зеіесйоп Роптшіа Есіііог 

{СизРотег.Кедіоп} = {ЗКедіоп} 

включит в отчет только те записи, у которых значение поля Си$(отег.Кефоп 
совпадает со значением параметра ?Ке§іоп. 

Если параметр принимает одиночное значение, то расположенная в заго¬ 
ловке отчета формула 

"Отчет по региону" + ?Кедіоп 

вернет это значение, например "Отчет по региону СА". Если параметр при¬ 
нимает множественные значения, то такая формула вернет только первое 
значение. Для отображения всех значений в заголовке отчета следует ис¬ 
пользовать формулу: 

Ьосаі ШшЬегѴаг і; 

//функция ЬГВоипсІ возвращает размер массива 
Ьосаі ЗРгіпдѴаг гезиІР 
Рог і :=1 Ро ЬГВоипсІ ({?5РаРе}Шо 
( 

гезиІР := гезиІРѴ "+{?5РаРе> [і] ; 

) ; 

гезиІР 
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Сложное форматирование 
и специальные типы отчетов 

6.1. Форматирование секций 

В процессе создания отчетов часто возникает необходимость сложного фор¬ 
матирования секций отчета — иногда надо скрыть или показать ту или иную 
секцию в зависимости от значений содержащихся в ней полей, выделить 
секцию цветом, "наложить" одну секцию на другую и т. д. 

Для форматирования секции следует расположить курсор на секции в левой 
части вкладки Ое$і§п окна редактирования отчета и щелкнуть правой кноп¬ 
кой мыши. В появившемся контекстном меню следует выбрать пункт 
Рогтаі 8есйоп. Появляется диалоговое окно Весііоп Ехрегі (рис. 6.1). 

Вкладка Соішпоп диалогового окна Зесііоп Ехрегі: позволяет выбрать опции 
форматирования. Выбранные опции могут влиять на отчет непосредственно 
или же в зависимости от выполнения некоторого условия, см. разд. 6.2. Вот 
список возможностей. 

□ НМе — скрыть секцию с сохранением возможности просмотра детальной 
информации по выбранной группе (сігііі бо\ѵп, "высверливание"). 

□ 8иррге88 — скрыть секцию без возможности "высверливания". 

□ Ргіпі аі Воііот оГ Ра§е — печатать суммирующие значения только в кон¬ 
це страницы. 

□ Ра§е ВеГоге — перейти на новую страницу перед печатью секции. 

□ Ра§е АЙег — перейти на новую страницу после печати секции. 

□ Кевеі Ра§е ІѴитЬег АЙег — установить номер страницы в 1 после секции. 

□ Кеер То§еЙіег — не разрывать данные из одной записи на две страницы. 

□ 8иррге88 Віапк Зесііоп — скрывать пустые секции. 

□ Іішіегіау РоІІо\ѵіп§ Зесііоп — возможность "наложения" секции на сле¬ 
дующую секцию. 

□ Рогтаі \ѵійі МиКірІе Соіитп — возможность многоколоночного формати¬ 
рования. Эта опция позволяет, в частности, "продлить” отчет на несколько 
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страниц в ширину, для чего нужно выбрать эту опцию и на появившейся 
вкладке Ьауоиі установить ширину Оеіаіі 8йе больше ширины страницы. 
Отчет будет располагаться на нескольких страницах в ширину. Эта опция 
действует только при форматировании секции Беіаік. 

□ Кеагі-опіу — запрет на форматирование или изменение расположения для 
всех объектов секции. При включенной опции Кеагі-опіу все другие оп¬ 
ции диалогового окна Зесііоп Ехрегі недоступны. 

□ Кеіаііѵе Ро$іііоп$ — устанавливает для объектов секции относительную 
позицию. Включение этой опции полезно, если в секции размещены 
объекты, динамически изменяющие свой размер, например матричный 
отчет (Сго$8-ТаЬ). Если справа от Сго$$-ТаЬ на расстоянии 2 см помещен 
текстовый объект и включена опция Кеіаііѵе РовШош, то расстояние 
в 2 см будет сохраняться как в режиме Бе$щп, так и в режиме Ргеѵіеѵѵ. 
В противном случае Сго$$-ТаЬ может "закрыть" текстовый объект. 



Верогі Неасіег 
Раде Неасіег 

бгоир Неасіег Й1: Си$1отег.Соип1гу • А 
бгоир Неасіег Й2: Сизіоппег.СІІу • А 


' 


бгоир Гооіег № 2 : СизІотег.СІІу - А 
бгоир Гооіег #1: СизІотегСоипІгу - А 
Раде Гооіег 
Перогі Гооіег 


Г РгЬі а> Вг 


г—Г.. . . - ■ ■ “Г 


Г" ЯёагіАетІу 
Г" Вёіаііуе Рбзііюга 


Зесііоп Екреіі 


Рис. 6.1. Диалоговое окно Зесііоп Ехрегі 


Рассмотрим возможность "наложения" текущей секции на секцию, следую¬ 
щую за ней. Если в секции Ра§е Неасіег расположить рисунок и включить 
опцию Шёегіау Роііоѵѵіщ» Зесііоп, то отчет может выглядеть как на рис. 6.2. 
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Хотя поля Сизіопіег №те и Ьа$1 Уеаг’8 8а1е§ расположены в секции БеЫІз, 
рисунок располагается не над полями, а справа от них. Секция Ра§е Неагіег 
накладывается на секцию Ое(аі1$. 
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Рис. 6.2. Пример форматирования ІІпсІегІау РоІІоѵѵіпд ЗесГіоп 


Сгузіаі Керогіх 9 позволяет создавать множественные секции. Так, например, 
можно создать две секции Оеіаііз и каждую отформатировать по-своему. 
Чтобы создать новую секцию, следует в левой части диалога 8есйоп Ехрегі 
в списке выбрать секцию, например Ое(аіІ8, и щелкнуть на кнопке Іпвегі. 
Возникают две секции — Беіаііз а и Беіаііх Ь. 

Другой способ создания множественных секций — метод Ога§&Огор. Для 
создания новой секции следует переместить курсор на вертикальную полосу 
слева от секции, "захватить" ее, при этом возникает курсор в виде двух вер¬ 
тикальных разнонаправленных стрелок, и перетащить ее вниз на некоторое 
расстояние. Возникает новая секция. 

Таким способом можно создать любое количество секций. Каждую секцию 
можно отформатировать индивидуально, каждая секция может содержать 
совершенно разные объекты. 

Множественные секции позволяют строить очень сложные отчеты прекрас¬ 
ного качества. Рассмотрим несколько примеров использования множествен¬ 
ных секций, 

□ Если в одной секции расположить объекты переменной длины, например 
матричные отчеты или подотчеты, они могут при печати перекрывать 
друг друга. Расположение этих объектов в разных секциях обеспечит их 
правильное расположение при печати (рис. 6.3), 

□ В отчете может возникнуть необходимость отображения поля в разных 
форматах. Например, если в секции ОеІаіІ8 есть поля "Страна" и "Дата", 
дату следует отобразить в таком формате, который принят в данной стра¬ 
не. Можно создать несколько секций Ое(аіІ8, в каждой из них поместить 
поле "Страна" и отформатировать его индивидуально и, наконец, в диа¬ 
логовом окне 8есйоп Ехрегі установить опцию 8иррге88 (скрыть секцию) 


5 Зак. 1021 
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по условию так, чтобы для каждой страны показывалась секция с соот¬ 
ветствующим форматом даты. 

□ Установка различного цвета фона для четных и нечетных строк секции 
Ое(аі1$. Такой способ улучшает восприятие отчетов. Для этого необходи¬ 
мо создать две секции Оеіаііз, установить для них разный цвет фона на 
вкладке Соіог диалога 8есйоп Ехрегі, и установить опцию скрыть секцию 
по условию для четных и нечетных полей. 



Рис. 6.3. Расположение объектов переменной длины 
в разных секциях отчета 


Упражнение 6.1 

Используя в качестве источника данных таблицу Сизіотег, создайте отчет 
с полями СивіотегХаві Ѵеаг'8 8а1е8 и Сикіотег.Сихіогаег №те. Включите 
в отчет группировку по стране, по полю Си$(отег.СоипІгу 

Отформатируйте отчет так, чтобы информация о каждой стране располага¬ 
лась на отдельной странице. 


іпаегГ-Г] Реіеіе. Мв'9® 


Рис. 6.4. Группа кнопок диалогового окна Зесііоп Ехрегі 
для работы с множественными секциями 


При создании множественных секций в верхней части диалога 8ес1іоп 
Ехрегі становится доступной группа кнопок, показанная на рис. 6.4. 
Две правые кнопки этой группы служат для перемещения выделенной 
в списке секции относительно соседних, например, для изменения порядка 
множественных секций. Кнопка ІпвегЦ как было указано ранее, позволяет 
создать новую секцию. Кнопка Беіеіе удаляет секцию со всеми содержащи¬ 
мися в ней полями. Кнопка Мег§е также удаляет секцию, но все содержа¬ 
щиеся в ней поля отчета перемещаются в соседнюю. 
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6.2. Форматирование по условию 
и выделение данных 
с помощью НідЫідМіпд Ехрегі 

Сгузіаі КероЛз 9 позволяет форматировать объекты отчета по условию, на¬ 
пример в зависимости от значения поля отчета. Форматировать по условию 
можно как секции отчета, так и отдельные объекты. Для форматирования по 
условию необходимо щелкнуть на кнопке справа от окна выбора в редакто¬ 
ре форматирования, например 8есІіоп Ехрегі для форматирования секции 
или Рогіпаі Ейііог для форматирования поля отчета. Появляется окно 
Еогтиіа Егіііог. Если устанавливаемое свойство может принимать значения 
"да" — "нет", например Зирргезз, то возвращаемое значение формулы долж¬ 
но быть "истина" или "ложь". Если устанавливаемое свойство может прини¬ 
мать несколько значений, например цвет, то формула должна возвращать 
константу. В этом случае список констант появляется в верхней части спи¬ 
ска функций окна Еогтиіа ЕФіог (рис. 6.5). 
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Рис. 6.5. Список констант в окне Рогтиіа ЕсШог 


Упражнение 6.2 

Используя в качестве источника данных таблицу Сизіотег, создайте отчет и 
включите в него поля СизІотегХазІ Ѵеаг'з 8а1ез и СизІотег.СизІотег №те. 
Сделайте красным фон строк, у которых сумма покупок клиентов в про¬ 
шлом году была больше 30000. 

Для этого в режиме дизайна правой кнопкой мыши щелкните в правой 
части секции Беіаііз и в диалоговом окне 8ес1іоп Ехрегі (рис. 6.1) перейдите 
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на вкладку Соіог. Щелкните на кнопке справа от поля выбора Васк§гоши1 
Соіог и в окне Рогтиіа Ейііог введите формулу 

ІЕ {СизЪотег.ЬазІ: Уеаг'з 5а1ез}>30000 Йіеп сгКей еізе сгИоСоіог 

Для выделения наиболее значимой информации цветом или стилем шрифта 
можно использовать специальный инструмент — Ні§Ыі§№п§ Ехрегі. Для 
выделения объекта отчета следует переместить на него указатель, щелкнуть 
правой кнопкой мыши и выполнить команду контекстного меню 
Ні§Н]і§№п§ Ехрегі либо щелкнуть на кнопке вызова Ні§1іІіДіііп§ Ехрегі 
в панели инструментов для анализа (табл. 1.4). Появляется диалоговое окно 
Ні§Мі§1іііп§ Ехрегі (рис. 6.6). 
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Рис. 6.6. Диалоговое окно НідЫідЫіпд Ехрегі 


В левой части диалогового окна Ні§1і1і§1іііп§ Ехрегі содержится список логи¬ 
ческих условий форматирования объекта Ііет ІІ8І. Так, в примере на рис. 6.6 
создано два логических условия: 

Ѵа1ие<1000$ 

И 

Ѵа1ие>30000$ 

Для каждого логического условия в правой части диалогового окна можно 
задать предикат и действия, которые будут выполняться, если условие при¬ 
мет значение "истина". Для создания нового условия необходимо щелкнуть 
на кнопке для удаления существующего условия — на кнопке Кешоѵе. 
В списке может быть задано несколько условий, причем они могут противо- 
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речить друг другу. В этом случае приоритет будет иметь то условие, которое 
расположено выше. Для изменения приоритета условий следует воспользо¬ 
ваться кнопками Ргіогііу, при этом выделенное условие будет перенесено 
выше или ниже в списке. 

Для задания свойств следует переместить указатель на строку с условием 
и в группе Ііеш ЕгіВог выбрать необходимые опции: 

Ѵаіие оГ — группа из трех раскрывающихся списков, в которых следует 
выбрать объект отчета, логический оператор и значение. Значение Гіеіб 
в верхнем списке показывает, что условие будет строиться на основе поля, 
которое форматируется (т. е. было выбрано при вызове диалогового окна 
НфЫфМігщ ЕхрегІ). В примере на рис. 6.2 было выбрано поле Си8іотегХа8І 
Уеаг’8 8а1е$, оно же будет выделяться цветом. Однако можно, например, 
форматировать поле Сивіотег.СивІотег ^те в зависимости от значения 
поля СіЫотег.ЬазІ Уеаг'8 8а1е$. В этом случае следует вызвать диалог 
Ні§Мі§Ь{іп§ Ехрегі, установив указатель на поле Си$1отег.Си$1отег №те, 
а списке Ѵаіие о Г выбрать СивіотегХавІ; Уеаг’8 8аІе8. 

В примере на рис. 6.6 для второго в списке Ііет 1І81 условия выбраны значения: 

Йііз €іе1Д 

із дгеаЬег ьЬап ог есщаі Ьо 
30 000$. 

Эти значения соответствуют условию ѴаІие>30000$. 

Раскрывающиеся списки Ропі 8іу1е, Ропі соіог, Васк^гоипгі и Воггіег позво¬ 
ляют выбрать стиль и цвет шрифта, цвет фона, и стиль рамки объекта отче¬ 
та, которые будут установлены для объекта, если условие будет выполнено. 

В окне 8атрІе отображается пример шрифта, установленного с помощью 
списков Ропі 8іуІе, Ропі соіог, Васкдгоигкі и Воггіег. 

Упражнение 6.3 

Примером форматирования секций по условию может быть отчет, в кото¬ 
ром для различных категорий клиентов нужно отображать совершенно раз¬ 
ную информацию. Используя в качестве источника данных таблицу 
Сивіотег, создайте отчет и включите в него: 

1. Поля Сивіотег №те, СопіасІ ТШе, Сопіасі Рігві Nате, Сопіасі Ра8І 
Nате, Ро8ІаІ Со(1е, А(1(1ге88І и А(Ыге882, если значение поля СивіотегХаві 
Уеаг'8 8а1ев больше 10000. 

2. Поля СивІютег Nате и Ьаві Уеаг’8 8аІе8, если значение поля Си8- 
іотегХаві Уеаг'8 8а1ев меньше или равно 10000. В качестве источника 
данных используйте таблицу Сшіотег. 

Для такого отчета необходимо создать две секции Оеіаіів а и ОеІаіІв Ь 
(см. рсізд. 6.1). В секции БеІаіН а расположите поля Еа8і Уеаг'8 8аІе8, 
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Сивіотег Иате, Сопіасі Ткіе. Сопіасі Рігві ІѴате, Сопіасі Іщ$1 №те, Ровіаі 
Согіе, А(і<іге88І и А(1<1ге882, в секции Оеіаіік Ь — Ьаві Ѵеаг'8 8а1е8, Сивіотег 
ІЧате, Соипігу и Сііу. Затем следует перейти в диалоговое окно 8ес*іоп 
Ехрсгі и для опции 8иррге88 (N 0 ШШ-Осига) создать формулу форматирования. 

Для секции ОеіаіІ8 а: 

{СизЬотег.Ьаз*: Уеаг'з 5а1ез}<=10000 

Для секции Ое1аіІ8 Ь: 

{СизСотег.ЬазЬ Уеаг'з Заіез} >10000 

Секция Ое(аіІ8 а будет скрыта, если значение поля Еа$1 Уеаг'8 8аІе8 меньше 
или равно 10000, секция Ое1аіІ8 а будет скрыта, если значение поля Ьа8і 
Ѵеаг'8 8аІев больше 10000. 


6.3. "Высверливание" данных 
(РгіІІ Ооѵт) 

Отчеты могут содержать множество детальной информации и сложное груп¬ 
пирование, что может затруднять их восприятие. Например, отчет содержит 
две колонки — название страны и сумму продаж в каждой стране. При ана¬ 
лизе агрегатных данных отчета — сумма продаж в каждой стране — у поль¬ 
зователя может возникнуть необходимость просмотреть продажи в регионах 
отдельно взятой страны. После просмотра отчета по регионам может потре¬ 
боваться отчет по продажам в отдельном регионе и т. д. Отчет, включающий 
только детальную информацию, был бы слишком объемным. Отчет, вклю¬ 
чающий только суммарную информацию, не позволяет просматривать дета¬ 
ли. Для эффективного анализа данных необходимо иметь отчет, сочетаю¬ 
щий как суммирующую, так и детальную информацию только там, где это 
необходимо. Такой отчет должен быть, с одной стороны, компактным, 
с другой — достаточно подробным. Сгу$іа1 ЯерогІ$ 9 позволяет скрыть неко¬ 
торые секции отчета и показывать данные в скрытых секциях на дополни¬ 
тельной вкладке, тем самым, решив проблему детального анализа данных. 

Для создания такого отчета следует выполнить группирование и при форма¬ 
тировании секций Беіаіів, а также, в случае необходимости, секций Сгоир 
Неасіег и Сгоир Рооіег, для внутренних групп в диалоговом окне 8есііоп 
ЕхрегРвключить опцию Нігіе (ОпН-Боил ОК). После щелчка на кнопке ОК 
создается отчет, содержащий только суммирующую информацию. Для про¬ 
смотра детальной информации в режиме просмотра отчета на вкладке 
Ргеѵіе\ѵ можно дважды щелкнуть на заголовке группы. Создается новая 
вкладка, на которой показывается детальная информация, но не вся, а толь¬ 
ко соответствующая выбранной группе. В качестве названия вкладки ис¬ 
пользуется имя выбранной группы (рис. 6.7). 
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Рис. 6.7. Пример отчета с "высверливанием" (ОгіІІ Ооѵѵп) данных 


Количество вкладок с детальной информацией не ограничено. Вложенность 
групп, способных создавать вкладки, также не ограничена. Вкладка может 
соответствовать как заголовку внутренней группы, так и секции Эеіаііз. 

В отчетах Сгузіаі Керогіз 9 возможность "высверливания" данных сохраняет¬ 
ся не только для полей отчета, например, заголовка группы, но и для диа¬ 
грамм или географических карт. Если диаграмма или географическая карта 
созданы на основе суммирующей информации, то двойной щелчок в сег¬ 
менте диаграммы или области географической карты приведет к созданию 
новой вкладки с детальной информацией. 


Упражнение 6.4 

Используя в качестве источника данных таблицу Сікіотег, создайте отчет 
с полями Сикіотег.Сивіотег №те и Си8іотег.Ьа$<:Уеаг’$ 8аІе8. Сгруппируй¬ 
те данные по полям СіЫотег.СоиЩгу, СизІотег.Кефоп и СизІотег.Сііу. 
Скройте, выбрав опцию Нійе (ОгіІІ-Боѵѵп ОК), секцию Оеіаііз и секции 
Сгоир Неайег и Сгоир Рооіег для групп Си8іошег.Ке§іоп и Сивіотег.Сііу. 
В режиме просмотра отчета дважды щелкните на названии страны, региона 
и города. 

Для работы с отчетами, содержащими "высверливание" данных Сгу$Га1 
Керойз 9 содержит функцию БгіІШомтіСгоирЕеѵеІ , которая возвращает целое 
число — уровень "высверливания". Рассмотрим пример, когда формула, со¬ 
держащая текст 
Огіі ЦЭоадпСг оирЬеѵеІ 

размещена в секции Беіаіів, а отчет содержит три вложенные группы, при¬ 
чем (рис. 6.7) для секции Ое(аіІ8 и двух внутренних групп установлена оп¬ 
ция Нійе (ВгіІІ-Втѵп ОК). В этом случае формула вернет значение 3. 
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Использование функции ВгіІГОоѵѵпСгоирЬеѵеІ может быть полезно для 
проверки, является ли текущее окно результатом "высверливания". Тогда 
формула 

Дгіі ІРотшСг оирЬеѵе 1 > О 

вернет значение "истина", если применялось "высверливание". 


6.4. Этикетки (Маіі і_аЬеІ) 

Помимо стандартного отчета, диалоговое окно Керогі Ехрегі (разд. 2.1) по¬ 
зволяет создать три других специальных типа отчетов: Сгозз-ТаЬ, ОТАР 
и Маіі ЬаЬеІ. Для создания специального отчета в диалоговом окне Сгувіаі 
Керогіз СаІІегу (рис. 2.1) следует выбрать необходимый тип отчета. Содер¬ 
жание появляющегося диалогового окна Керогі Ехрегі зависит от типа вы¬ 
бранного отчета. 

Отчет печати этикеток (Маіі ТаЬеІ) позволяет создавать этикетки или печа¬ 
тать адреса на конвертах на основе информации, хранящейся в базе дан¬ 
ных. После выбора типа отчета Маіі ЬаЬеІ в диалоговом окне СгукіаІ Керогіз 
СаІІегу открывается мастер отчетов МаіІіп§ ЬаЪеІк Керогі Сгеаііоп ѴѴі/апІ. 
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Рис. 6.8. Окно ЬаЬеІ мастера Маіііпд ЬаЬеІз ВерогТ СгеаНоп ѴѴігагсІ 
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Окна мастера — Оаіа, ІЛпк, Ріеіёв и Кесогй 8е1есбоп не отличаются от соот¬ 
ветствующих окон мастера 8(ап<іаг(1 Керогі Сгеаііоп \Ѵігап1 (см. рис. 2.2-2.4 
и рис. 2.9). В них следует выбрать источники данных, которые будут ис¬ 
пользованы для создания отчета, связать таблицы и задать условия выборки 
данных. 

В окне ЬаЬеІ мастера МаіІіп§ ЬаЬеІ8 Керогі Сгеаііоп \Ѵігаггі (рис. 6.8) можно 
выбрать тип этикетки или создать этикетку собственного формата. Раскры¬ 
вающийся список МаіІіп§ ГаЬеІ Туре содержит набор форматов для конвертов, 
товарных меток, форматы этикеток для видео- и аудиокассет, дискет и т. д. 

Поля раздела ІЧшпЪег оГ ЬаЬеІ8 показывают, сколько этикеток будет расположе¬ 
но вдоль (Бойн Ра§е) и поперек (Асго88 Ра§е) страницы. Эта информация вы¬ 
числяется автоматически в зависимости от размера страницы, рамок и т. д. 

Группа Ра§е Магфп позволяет регулировать отступы от краев страницы. 

Опция ЬаЬеІ 8іге позволяет регулировать размер создаваемой этикетки — 
высоту и ширину. 

Группа Сар ВееСѵіп ГаЬеІ8 позволяет задать интервалы между соседними 
этикетками по вертикали (ѴегбсаІ) и горизонтали (Ногі/опіаі). 


6.5. Матричный отчет 
(Сгозз-ТаЬ) 

Очень часто данные хранятся в таблицах базы данных в неудобной для соз¬ 
дания отчета форме. Рассмотрим, например, таблицу "Квартальные плате¬ 
жи", содержащую три поля — "Плательщик", "Квартал" и "Сумма платежа" 
(табл. 6.1). 


Таблица 6. 1. Пример хранения данных в таблице Квартальные платежи 


Плательщик 

Квартал 

Сумма платежа 

Иванов 

1 

200 

Петров 

2 

300 

Петров 

3 

100 

Сидоров 

2 

200 

Иванов 

2 

300 

Иванов 

3 

200 


Предположим, что перед нами стоит задача создать отчет следующего вида 
(табл. 6.2). 
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Таблица 6.2. Пример матричного отчета 

Плательщик 

Сумма 
платежа 
за 1 квартал 

Сумма 
платежа 
за 2 квартал 

Сумма 
платежа 
за 3 квартал 

Сумма 
платежа 
за 4 квартал 

Иванов 

200 

300 

200 


Петров 


300 

100 


Сидоров 


200 




В отчете (табл. 6.2) необходимо представить данные в компактном матрич¬ 
ном формате, как бы "развернуть" данные в матрицу. Такое представление 
данных характерно для электронных таблиц. Отчет, по структуре совпадаю¬ 
щий с этой таблицей, можно создать, используя формулы Сгѵмаі Кероііз 9, 
но создание отчета с применением формул трудоемко и может потребовать 
много времени. Еще более сложная задача возникает, если количество ко¬ 
лонок произвольное, а не по количеству кварталов, как в примере. 

Для создания матричных отчетов Сгу$іа1 К.ероЛ$ 9 имеет специальный инст¬ 
румент — объект Сго88-ТаЬ. 

Сго88-ТаЬ — матричный объект, который выглядит как электронная таблица. 
Этот объект содержит минимум три поля базы данных: 

1. Поле строки. 

2. Поле столбца. 

3. Суммарное поле. 

Для создания матричного отчета можно воспользоваться мастером Сго88-ТаЪ 
Керогі СгеаДоп ѴѴіхагф который вызывается из СгувіаІ Керогів СаІІегу 
(рис. 2.І). Другой вариант — вставить в обычный отчет, который уже содер¬ 
жит секцию Эеіаііз, а также одну или более групп, объект Сго88-ТаЬ, 
выполнив команду меню Ішегі | Сго88-ТаЬ либо нажав кнопку на панели 
инструментов для вставки объектов в отчет (табл. 1.3). Вставленный объект 
становится частью отчета. Матричные отчеты могут быть, помещены либо 
в заголовок (Ра§е Неагіег) или подвал страницы (Ра§е Рооіег), но не в сек¬ 
цию Беіаіів. Форма курсора будет указывать на невозможность такого дей¬ 
ствия при попытке поместить матричный отчет в эту секцию. 

Окна мастера Сго88-ТаЬ Керогі СгеаДоп ѴѴігагчі — Оаіа, ІЛпк и Кесоггі 8еІес~ 

Доп идентичны соответствующим окнам мастера 8іапДагД Керогі СгеаДоп 
ѴѴіхапІ (см. рис. 2.2, 2.3 и 2.9). В них следует выбрать источники данных, 
которые будут использованы для создания отчета, связать таблицы и задать 
условия выборки данных. 

Окно Сго88-ТаЪ (рис. 6.9) содержит окна для формирования полей, которые 
составят строки, столбцы и суммирующие поля матричного отчета. Для вне- 
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сения поля базы данных в матричный отчет, в списке окна АѵаіІаЫе Ріе1(І8 
следует выбрать поле и затем щелкнуть на кнопке > слева от окна К(МѴ8 для 
использования поля в качестве строки матричного отчета, Соішпш — ко¬ 
лонки, Зшшпашей Ріе!<І8 — суммирующего поля. Можно также добавить 
поля в матричный отчет, просто перетащив их методом Ога§&Огор из окна 
АѵаіІаЫе РіеМз в окна К<№8, Со1штш8 или ЗшшпашеЛ РіеІ<І8. 



Ш5 Сго*$-ТаЬ Вероіі Сгеаііоп Ѵ/ігагсі 


^|Ьиз(ОГпеГ| 


Сюк-Т аЬ 

Мб гот. соіитпз апб зиттагігегі ІіеЙз Іо !Ье сгозз-ІаЬ Ііот ’Ье аѵаіІаЬІе НеНз. 


АѵаіІаЫе РіеЫз: 


Сгозз-Т аЬ 


роіитг.5- 


РюНис(_Т уреРіесІис: Ту| 


Ш Ш 0гсІегз_0еЕаіІ 
Ш [Щ РЫисІ 
®3 Ш Ргосіис^Т уре 


5>итп>аіу РіеІсЬ Ж 
ІХ 5ит о( ОкІыѵ.Оіііес Атіх . 


Сиііотег.Иу. 


Рис. 6.9. Окно Сгозз-ТаЪ мастера Сгозз-ТаЬ Керогі Сгеаііоп ѴУігаггі 


В матричный отчет в качестве столбцов или строк могут быть включены не¬ 
сколько полей баз данных. В этом случае строки и столбцы выстраиваются 
иерархически, например, если в качестве столбца выбраны Сошкгу, Ке§іоп 
и Ску. При этом создаются групповые связи между полями, в одной стра¬ 
не — несколько регионов, в одном регионе — несколько городов. Конечно, 
поля должны располагаться в правильном порядке: верхнее — Соипігу, затем 
Ке§іоп и нижнее — Ску. Если порядок неправилен, поле можно переместить 
в окнах Ко\ѵ8 и Соіитпв методом Ога§&Огор. Иногда требуется показать 
несколько независимых колонок или строк в матричном отчете, например 
отобразить стоимость, плановую стоимость и дисперсию. К сожалению, 
отображение независимых колонок на одном уровне невозможно, поскольку 
множественные поля Ко\ѵ8 или Со1иіші8 в матричном отчете Сгузіаі Кероііх 9 
всегда показываются в групповой иерархии. 













134 


Гпава 6 


Для каждой группы будет вычисляться собственная сумма. Суммирующих 
полей также может быть несколько, например Оиапіііу 8о1«і (Количество 
продаж) или Оггіег Ашоипі (Сумма заказов). Матричный отчет просто вклю¬ 
чит два числа в каждую ячейку. Если в качестве суммирующего поля выби¬ 
рается числовое поле, Сгузіаі Керойз 9 вычисляет сумму поля для каждой 
ячейки с помощью функции 8ігаі; если поле с другим типом данных — будет 
показано количество одинаковых значений поля для каждой комбинации 
строка/столбец с помощью функции Соипі. Если нужно выбрать агрегатную 
функцию, отличную от функции по умолчанию, например, среднюю величи¬ 
ну продаж, то следует раскрыть список снизу от окна 5ишшагйе(1 Ріеііів. 

Окно СЬагі (рис. 6.10) предназначено для создания диаграммы на основе 
матричного отчета. 



СНагІ 


(Орііопаі) ІпсЫе а сНай оп (Не герой. 


1 Щ ^ 

*-:Г Г«оСЬо.ч .Й* \ Г Ріе'СЬаіІ ® ■ 

V ' 

Гу«. .А..'А;' ..' - ' . ...•/ г-' . : 


|^8ит бгсіег Атоипі / Ргогіисі Туре Ыате & Соипігу 

МШІІШІІ'' : 


||||Ж Ргосіис^Туре.РгоеІисІ Туре Мате 


^ 5ит о? ОгсІегз.ОгсІег Атоипі 


СапсеІ 


33 Сю$$ТаЬ Керогі Сіеаііоп Ѵ/ігаг<і 


[Ст*отег : СоипйИ 


Рис. 6.10. Окно СНагІ мастера Сгозз-ТаЬ Йерогі Сгеаііоп ѴѴігаггі 


В верхней части окна следует выбрать один из трех типов диаграммы: Ваг, 
Цпе или Ріе. Важно выбрать наиболее подходящий для отображения мат¬ 
ричного отчета тип диаграммы. Так, диаграмма типа Ваг может иметь три 
размерности — строка, столбец и суммирующее поле. В раскрывающихся 
списках Оп сНап^е оГ, 8иЬ<1іѵі<1е<1 Ьу и 8Ь<нѵ кшптагу можно указать поля от¬ 
чета, которые будут использоваться для размерностей диаграммы. В поле 
СНагІ (Ше следует ввести заголовок диаграммы. 
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В окне Сгіё 81у1е (рис. 6.11) можно выбрать один из семнадцати предопре¬ 
деленных стилей таблицы матричного отчета. 


Рис. 6.11. Окно Сгігі Зіуіе мастера Сговв-ТаЬ Рерогі Сгеаііоп ѴѴігагсІ 


После щелчка на кнопке РіпІ8Іг создается отчет, содержащий объект 

Сго$$-ТаЬ. 

Для внесения объекта Сго88-ТаЪ в существующий отчет следует выполнить 
команду меню Іпвегі | Сго88-ТаЬ или щелкнуть на кнопке вставки матрич¬ 
ного отчета в панели инструментов для вставки объектов в отчет (табл. 1.3), 
после чего переместить указатель на секцию отчета, в которую нужно вста¬ 
вить Сго88-ТаЪ, и щелкнуть кнопкой мыши. 

Для редактирования визуального отображения существующего объекта 
Сго88-ТаЬ следует выделить его целиком, а не только одно из полей, входя¬ 
щих в его состав. Для этого нужно щелкнуть мышью либо в небольшой 
незаполненной области в левом верхнем углу Сго88-ТаЬ (над первой строкой 
и слева от первого столбца), либо на линиях сетки между ячейками. После 
этого необходимо выполнить команду контекстного меню Рогшаі Сго88-ТаЬ 
или в команду главного меню Рогшаі | Рогшаі Сго88-ТаЬ. Появляется диа¬ 
логовое окно Рогшаі Егіііог, которое идентично диалоговому окну для редак¬ 
тирования свойств полей отчета (рис. 2.12). 


I Сіо*$-ТаЪ ИероіІ Сіеаііоп Ѵ/ігаггі 
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Снт-ТаЬ Гкреіі 
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Рис. 6.12. Вкладка Сгозз-ТаЬ диалогового окна Сгозз-ТаЬ Ехреіі 


Для изменения свойств созданного объекта Сго88-ТаЪ следует щелкнуть 
по нему правой кнопкой мыши и в контекстном меню выбрать пункт 
Сго88-ТаЬ Ехрегі. Возникает диалоговое окно Сго88-ТаЬ Ехрегі с вкладками 

Сго88-ТаЬ, Зіуіе, Сихіоші/е 8(уІе. 

Появляется диалоговое окно Сго88-ТаЬ Ехрегі, имеющее три вкладки — 
Сго88-ТаЬ, 8Гу1е и Сівіотаге 8«у1е. Вкладка Сго88-ТаЬ (рис. 6.12) так же, как 
окно Сго88-ТаЬ мастера Сго88-ТаЬ.Керогі Сгеайоп ЛѴі/аггі служит для выбора 
полей базы данных, на основе которых создается Сго88-ТаЬ. Но в отличие от 
мастера Сго88-ТаЬ Керогі СгеаВоп ѴѴігапі здесь можно использовать не толь¬ 
ко поля базы данных, но и формулы. Например, в базе данных содержится 
поле с датой заказа Огйегв.Огйег Баіе. Необходимо создать матричный отчет 
с суммированием по кварталам. Для этого нам нужно создать формулу 
((Зиагіег), которая определит квартал заказа, кнопкой №\ѵ Рогтиіа 
(рис. 6.12). Текст этой формулы следующий: 

Іі топЬіі ( {ОгсІегз.Огсіег БаЬе }) іп 1 (;о 3 Ыіеп "ІзЬ ОиагЬег" 

еізе іі топЫі ({ОгсІегз.Огсіег БаЬе }) іп 4 Ьо 6 Ыіеп "2п<3 ОиагЬег" 

еізе іі топіШ ({ОгсІегз.Огсіег БаЬе }) іп 7 Ьо 9 Ыіеп "Згсі ОиагЬег" 

еізе "2гсі ОиагЬег" 
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Во вкладке Сго88-ТаЬ можно изменить агрегатную функцию суммарного по¬ 
ля. Для этого необходимо выбрать суммарное поле в списке суммарных по¬ 
лей ЗиішпагігеЛ РіеМ$ в правой нижней части вкладки Сго88-ТаЬ и щелкнуть 
на кнопке СЬап§е 8шшпагу. Появляется диалоговое окно СЬап§е 8шпшагу 
(рис. 6.13), в котором можно выбрать другую агрегатную функцию. Если 
выбрать опцию 8Ьо\ѵ ав-а регсеп(а§е оГ, то в матричном отчете будет отобра¬ 
жаться не абсолютное значение суммирующего поля, а его доля в процентах 
от величины, выбранной в раскрывающемся списке в нижней части диало¬ 
гового окна СЬаіще 8шшпагу. Заметим, что в матричных отчетах суммарные 
поля (8иттагі/е<і РіеМ) могут быть только числовыми и не могут иметь тип 
"текст" или "дата". 
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: ’У 


0< | : ■ СапсеІ Неір 


Рис. 6.13. Диалоговое окно СЬапде Зиттагу 


При формировании матричного отчета Сгу$ШІ КероіТз 9 группирует данные 
по полям, указанным в качестве строк и столбцов. Для изменения порядка 
группировки следует на вкладке Сго88-ТаЬ диалогового окна Сго88-ТаЬ 
Ехрегі выделить поле строки или столбца, которое необходимо изменить, и 
щелкнуть на кнопке Сгоир Орііопз. Появляется диалоговое окно Сго88-ТаЬ 
Сгоир ОрНоп8 (рис. 6.14). 

Диалоговое окно Сго88-ТаЬ Сгоир Орйопв аналогично окну Іпвегі Сгоир 
(рис. 3.6), используемому для задания порядка группировки в стандартном 
отчете. Для поля, отличного от поля даты, доступны три опции: 

□ Азсеп(1іп§ Опіег — отображение строки или столбца матричного отчета по 
алфавиту в порядке возрастания; 

□ Ое8сеп(1іп§ Огйег — отображение строки или столбца матричного отчета 
по алфавиту в порядке убывания; 





138 


Глава 6 


□ Зресійей Огёег — возможность создавать строки или столбцы на основании 
содержимого полей базы данных, отобранных для строки или столбца. 



Гскт-ТаЬ бгоир Ор(іопг 


| Оріірпа | 

. ѴЛепі ІНечаройв рппІеі'Кзе-іесоісй.иіІТ Ье «*Ы ап& 


Рис. 6.14. Диалоговое окно Сгозв-ТаЬ Сгоир Орііопв 
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Рис. 6.15. Вкладка Сизіотіге Зіуіе диалогового окна Сго55-ТаЬ Ехрегі 
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Если поле строки или столбца является полем даты, времени или да¬ 
ты/времени, диалоговое окно Сго88-ТаЬ Огоир Орбопв предлагает дополни¬ 
тельные опции. Так, например, в одну группу могут быть объединены запи¬ 
си по значению поля типа дата за один день, одну неделю, месяц, квартал, 
год и т. д. (Піе соіитп (г<т) >ѵШ Ье ргіпіей). Раскрывающийся список 
ТНе ѵаіие ргіпіей Гог Іііе соіитп (пт) ѵѵііі Ье предоставляет две возможности 
выбора: начальная дата периода и конечная дата периода. 

Вкладка 8іу1е идентична окну Сгі<1 8іу1е мастера Сго88-ТаЬ Керогі Сгеаііоп 
ѴѴігагё (рис. 6.11). 

Для дополнительного форматирования объекта Сго88-ТаЬ необходимо ис¬ 
пользовать вкладку СивГотіге 8*у1е (рис. 6.15). 

В верхней части вкладки Сивіопше 8Гу1е расположены окна Кст8 и СоІитп8. 
Одновременно можно выбрать только один объект (строку или столбец мат¬ 
ричного отчета) в одном из двух окон. Именно для этого объекта можно 
установить свойства с помощью элементов управления, расположенных 
в нижней части вкладки. В табл. 6.3 приведены опции форматирования 
строк и столбцов матричного отчета. 

Таблица 6.3. Опции форматирования строк и колонок матричного отчета 


Опция Описание опции 


Зирргезз ЗиЫоІаІ Скрывает промежуточную сумму по строкам или столбцам для 
выбранного поля, если создана иерархия по строкам или 
столбцам, т. е. в качестве строк или столбцов выбрано более 
одного поля базы данных 


Зирргезз 1_аЬе| Опция становится доступной, если выбрана опция Зирргезз 
ЗиЫоІаІ. Скрывает поле верхнего уровня в иерархии 


АНаз Гог Рогтиіаз 


ВаскдгоипР Соіог 


Используется для ссылки на целую строку или столбец при 
выполнении условного форматирования в матричном отчете 

Устанавливает цвет фона для строки или столбца 


ЗГіош Сеіі Магдіпз Окружает ячейки свободным пространством со всех сторон. 

Отключение этой опции позволяет размещать ячейки более 
компактно 


Іпсіепі Роѵѵ І_аЬеІз Выбор этой опции приводит к отступу подписи ЦаЬеІ) выбранной 
строки от левого края матричного отчета. Величина отступа 
строки задается в поле снизу от окна выбора Іпгіепі Воѵѵ І_аЬеІз 

Рогтаі Сгісі Ыпез Вызывает диалоговое окно Рогтаі Сгісі Ыпез, которое пред¬ 
назначено для задания формата линий сетки в матричном 
отчете 


Кеер Соіитпз Защищает столбцы от разбиения, когда распечатываемая таб- 
ТодеГЬег лица превосходит по ширине страницу и таблица должна быть 

распечатана на двух или более страницах 
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Таблица 6.3 (окончание ) 

Опция 

Описание опции 

Вереаі Воѵѵ 

ЪаЬеІз 

При выборе Кеер Соіитпз ТодеіЬег повторяет метки строки, 
если ширина матричных отчетов превышает ширину страницы 

Яоѵ/Тоіаізоп ЬеЛ 

Отображает итог по строкам слева, а не справа строк 

Соіитп Тоіаіз оп 
Тор 

Отображает итог по столбцам вверху, а не внизу от текущей 
колонки 

Зирргезз Етріу 
Воѵѵз 

Скрывает строки, не содержащие данных 

Зирргезз Етріу 
Соіитпв 

Скрывает столбцы, не содержащие данных 

Зирргезз Вош 
Огапсі Тоіаі 

Скрывает общий итог строки 

Зирргезз Соіитп 
СгапсІ Тоіаі 

Скрывает общий итог столбца 


Объект Сго88-ТаЬ можно также "транспонировать", поменяв местами строки 
и столбцы. Для этого нужно выполнить команду главного меню Рогтаі | 
Ріѵоі Сго88-ТаЪ или щелкнуть правой кнопкой мыши на Сго88-ТаЬ и выпол¬ 
нить команду контекстного меню Ріѵоі Сго88-ТаЬ. 

Матричный отчет создается в несколько этапов. На каждом этапе произво¬ 
дятся вычисления лишь по одной комбинации строки и столбца, поэтому 
формируется матричный отчет сравнительно медленно. Если поместить объ¬ 
ект Сго88-ТаЬ в заголовок или подвал отчета (секции Керогі Рооіег и Керогі 
Неайег), то он появится в отчете только в одном экземпляре. Этот Сго88-ТаЬ 
будет обобщать все данные отчета. Если поместить объект Сго88-ТаЬ в заго¬ 
ловок или подвал группы (секции Сгоир Рооіег и Сгоир Неаііег), то в ре¬ 
зультате объектов будет столько, сколько существует групп, и в каждый 
Сго88-ТаЬ будут включены данные только этой группы. 

После внесения в секцию отчета, на вкладке Ое8І§п объект Сго88-ТаЬ выгля¬ 
дит как набор дочерних полей (рис. 6.16): 

□ суммирующее поле; 

□ заголовок столбца, отображаются поля базы данных; 

□ заголовок суммы по колонкам — текстовый объект; 

□ заголовок строки, отображаются поля базы данных; 

□ заголовок суммы по строкам — текстовый объект; 

□ сумма по столбцам; 

□ сумма по строкам; 

□ итоговая сумма. 
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Заголовок строки 


Суммирующее 
поле 


Заголовок столбца Заголовок суммы по строкам 



Ьоіитп#! Ыате 1 

ч 

'Гоіаі I 

^оад#1 Ыате ’ 

[Бит о* Огііегз.Огсіег АтоипІ 

[5ит оГ Огйегз.огйег Атоиггі] 

Тоіаі у 

5ит оГ Огііегв.Огііег Антоши 

1_ г. _1 

г 5ит оГ 0г<іег5.0гЛег Атоипі 

2_ 1 _' 


Заголовок суммы 
по столбцам 


Сумма по столбцам 


Итоговая сумма 


Рис. 6.16. Представление объекта Сговз-ТаЬ в режиме Оезідп 

Каждый дочерний объект Сго$8-ТаЬ может быть отформатирован индивиду¬ 
ально, в том числе по условию, как обычное поле отчета в редакторе Рогтаі 
Ейііог. Размер дочернего объекта можно изменить так же, как размер обыч¬ 
ного поля. Можно выделить несколько объектов в матричном отчете, а за¬ 
тем отформатировать их все одновременно. Для условного форматирования 
используется диалоговое окно Ні§Мі§Ьііп§ Ехрегі, вызывается щелчком 
правой кнопки на объекте и выполнением команды контекстного меню 
Ні§Ыі§Ііііп§ Ехрегі. Также для условного форматирования используются 
формулы, они содаются в диалоговом окне Рогтиіа Егіііог, которое вызыва¬ 
ется кнопкой условного форматирования в диалоговом окне Рогтаі Егіііог. 
При создании формул условного форматирования матричного отчета нельзя 
использовать поля базы данных или поля промежуточных сумм матричного 
отчета. При ^условном форматировании матричных отчетов необходимо ис¬ 
пользовать встроенную функцию Сиггепі Ріеій Ѵаіие, которая возвращает 
текущее значение форматируемого поля. Например, приведенная ниже 
формула позволяет окрасить поле матричного отчета в красный цвет, если 
значение поля больше 20000: 

іі СиггепЬРіеІдѴаІие > 20000 Йіеп Кед еізе ШСоІог. 

Для условного форматирования на основе суммы по строке или столбцу, 
а не только на основе значения поля, следует использовать функцию 
СгнШоѵѵСоІитпѴаІие. С помощью функции СгійКтѵСоІитпѴаІие можно оп¬ 
ределить строку или столбец, в котором находится поле, например 
ІЕ СгійКоадСоІіштѴаІиеС'СизЬошег.Кедіоп") = "СА" ЬЪеп Кед еізе ЯоСоІог 

В качестве аргумента функции Огі(іКо\ѵСо1итпѴаіие допускается использо¬ 
вание не имени поля, а его псевдонима. Псевдоним задается в поле АНа« ібг 
РогтиІа$ вкладки Сизіопше 8іу1е диалога Рогтаі Сго88-ТаЬ. 

На основе данных матричного отчета можно создать диаграмму. Для этого 
нужно выделить объект Сго88-ТаЬ и выполнить команду меню Іпвегі | СІіагі. 
Диаграмма, построенная на основе Сго88-ТаЬ, должна иметь три размерности: 
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строка, столбец и суммирующее поле. На вкладке Туре диалога СЬагі Ехрегі 
необходимо выбрать подходящий тип диаграммы — ЗБ Ківег или 
30 8игГасе. На вкладке Баіа содержатся списки выбора Оп сЬап§е оГ, 
8уЬ(1іѵі(1есІ Ьу и 8ію\ѵ, в которых следует указать поля матричного отчета, ис¬ 
пользующиеся в качестве размерности диаграммы. Как правило, в списках 
Оп сЬап§е оГ и 8уЬ<Иѵійе<і Ьу выбирается строка и столбец, а в качестве 
8Ь<т — суммирующее поле. 

Упражнение 6.5 

В файле хігетелткіЬ имеются таблицы Сихіошег и Ргойисі Туре. В таблице 
Сивіотег содержится информация о городах проживания клиентов, в табли¬ 
це Ргогіисі Туре — ■ наименование типов продаваемых продуктов. Необходи¬ 
мо создать отчет, показывающий объем продаж типов продуктов в городах 
Канады. Таблицы Сивіотег и Ргойисі Туре связаны между собой через три 
промежуточные таблицы — Огйегв, Оггіегв Беіаіі и Ргойисі Сумма продаж 
определяется как сумма заказов в поле Огйегв.Огйег Апіоипі, сделанных по 
каждому типу продуктов в каждом регионе. 

Для создания отчета следует выполнить следующие шаги: 

1. При создании нового отчета выбрать тип отчета Сго88-ТаЪ. 

2. Выбрать источник хігегпе.тсІЬ. 

3. Ввести таблицы Сивіотег, Опіеге, Ог<1ег8 ПеіаіІ, Ргогіисі, Ргойисі Туре и 

связать их на вкладке ІЛпк8, по умолчанию связи автоматически устанав¬ 
ливаются корректно. 

4. В окне Сго88-ТаЬ в качестве строки Ко>ѵ8 выбрать поле Сщіотег.Сивіопіег 
Сііу, в качестве столбца Соішппв — Ргойисі Туре.Ргойисі Туре Nате и 
в качестве суммирующего поля 8шшпагІ2е(1 РіеІЙ8 — Огйеге.Огйег Апіоипі. 

5. В окне СЬагі выбрать тип диаграммы Ваг СЬагі и указать размерности 
диаграммы: Оп сЬап§е оГ — Сивіошег Сііу. 8уЬйіѵійей Ьу — Ргойисі Туре 
N 8016 , 8Ьо\ѵ 8иштагу — 8ит оГ Огйегв.Огйег Апіоипі. 

6. В окне Кесоггі 8е1есііоп$ задать правила отбора данных: 

СизСотег .СоипСгу із едиаі Со "Сапайа" 

И 

РгоДисС Туре Цате із поС едиаі Со "" 

7. После щелчка на кнопке РіпівЬ создается матричный отчет. Следует от¬ 
метить, что тип диаграммы Ваг СЬагі нельзя назвать удачным для ото¬ 
бражения данных матричного отчета. Для изменения типа диаграммы на¬ 
до щелкнуть на ней правой кнопкой, выполнить команду контекстного 
меню СЬагі Ехрегі и на вкладке Туре диалогового окна СЬагі Ехрегі 
выбрать тип ЗБ Ківег. 

Результат выполнения упражнения показан на рис. 6.17. 
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Зит оГ Окіег Атоипі I Сііу & Ргосіисі Туре Ыате 




Сотреіій 

ОІоѵез 

Неітеіз 

НуЫМ 

Кійз 

І-оскз 

Моипіаіп 

баййіез 

Ѳ еа сопзЛе Ісі 

1 800$ 

0$ 

0$ 

0$ 

0$ 

0$ 

0$ 

0$ 

ѲцгпаЬу 

44 471$ 

1 002$ 

9 109$ 

1458$ 

1344$ 

149$ 

16 028$ 

16 884$ 

НаІіГах 

0$ 

0$ 

0$ 


0$ 

0$ 



ОІІама 

0$ 

0$ 

0$ 

0$ 

274$ 

0$ 



Рогі С очи ІІІат 

126 963$ 

17 621$ 

40 477$ 

6 932$ 


7 349$ 

27 944$ 

3 607$ 

Тогопіо 

8 820$ 

0$ 

0$ 

0$ 

0$ 

0$ 

0$ 

0$ 

Ѵапсоиѵег 

58 756$ 


25142$ 

35 336$ 

6410$ 

5 706$ 

39 461$ 

18 250$ 

ѴѴіппіред 


0$ 

0$ 

0$ 

0$ 

0$ 

864$ 


Тоіаі 

240 810 р. 

27 860 р. 

74 729 р. 

43 726 р. 

9 253 р. 

13 204 р. 

85 256 р. 



Рис. 6.17. Пример матричного отчета, содержащего диаграмму 


6.6. Отчет, содержащий 
подотчеты (ЗиЬгерогІ) 

Подотчет (зиЬгероЛ) — это отчет, входящий в состав другого отчета. Подот¬ 
чет является полноценным отчетом и может быть связан или не связан 
с основным отчетом. В качестве подотчета можно использовать существую¬ 
щий отчет или создать новый. Подотчет может быть включен в любую сек¬ 
цию отчета как объект 8 иЬгерог1 Хотя основной отчет может содержать лю¬ 
бое количество подотчетов, подотчет не может содержать другой подотчет. 

Подотчеты позволяют представить данные с разных точек зрения или свя¬ 
зать данные из разных источников. Например, основной отчет может 
содержать группу по регионам, а подотчет — группу Тор N и диаграмму, 
иллюстрирующую распределение продаж в нескольких крупнейших регионах. 
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Другой пример использования подотчетов — связывание данных, хранящих¬ 
ся в разных базах данных. Например, в результате перехода на новую ин¬ 
формационную систему часть данных предприятия хранится в СУБД Огасіе, 
часть — в РВР-файлах. Основной отчет может использовать в качестве ис¬ 
точника Огасіе, подотчет, размещенный в секции ОеіаіІ8, — файл типа ОВР. 
Данные основного отчета и подотчета могут быть связаны по значению поля 
базы данных, по формуле или по параметру. Например, если табельный но¬ 
мер сотрудника, хранящийся в Огасіе, — целое число, а в файле ОВР — 
строка, то отчет и подотчет могут быть связаны с помощью формул. Кроме 
отчета с подотчетами, Сгу$іа1 Керогія 9 не имеет средств создания отчета из 
разнородных источников данных. 

Для включения подотчета в существующий отчет следует выполнить коман¬ 
ду меню Іпяегі | БиЬгерогі или щелкнуть на кнопке вставки подотчета в па¬ 
нели инструментов для вставки объектов в отчет (табл. 1.3), после чего 
щелкнуть кнопкой мыши на любой секции отчета. 

Возникает диалоговое окно Іпяегі БиЪгерогІ, которое содержит две вклад¬ 
ки — 8 иЬгерогі (рис. 6.18) и Упк. 


ІПіегІ ВиЬгсроП 


ЗиЫераІ |ііпк ] 

; Ігоег: ЯиЬгерск! - 
у ' ѵ ; СЬогае а гедоіі ; ■ 

■ | і ; Г с ѴуѴу - \ | 

ілеаіе а яіЬіерогі 


у--/ 


Верой N«1* у :|ЗиЬгерогП 




Верог(У%агД.. 


ш 


СапсеІ 


Нѳір 


Рис. 6.18. Вкладка ЗиЬгерогІ диалогового окна Іпвеіі ЗиЬгероіі 


На вкладке 8 иЬгерогІ можно указать существующий отчет, который будет 
использоваться в качестве подотчета, для этого используется радиокнопка 
СНоо$е а герогі. поле Керогі Рііе Nате и кнопка Вптве. Можно создать но¬ 
вый отчет, используя радиокнопку Сгеаіе а яиЬгерогі. поле Керогі Рііе ІЧате 
и кнопку Керогі \Ѵігап1. Для создания нового отчета необходимо ввести 
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в поле его имя и щелкнуть на кнопке Керогі ѴѴі/апІ, которая вызывает мас¬ 
тера отчетов 8іап<іагё Керогі Сгеаііоп ѴУігаггі (разе) 2.1). Если основной отчет 
и подотчет связаны, то выполнение отчета может занять много времени, 
поскольку связывание данных производит Сгузіаі Керогіз 9, а не сервер базы 
данных, и индексы при этом не употребляются. Для увеличения производи¬ 
тельности при отображении отчета с подотчетом на экране используется 
опция Оп-Леташі $иЪгерогі. Если эта опция включена, то в режиме предва¬ 
рительного просмотра отображается только имя подотчета, а не его содер¬ 
жимое, то есть подотчет не выполняется (рис. 6.19). 



Рис. 6.19. Пример отчета с включенной опцией Оп-сіетапсі зиЬгероіі 


Для просмотра содержимого подотчета необходимо дважды щелкнуть на его 
имени. При этом Сгузіаі Керогіз 9 создает новую вкладку, на которой ото¬ 
бражается содержимое подотчета, т. е. отчет с подотчетом выполняется так 
же, как отчет с "высверливанием" данных БгШ Б<иѵп. 

Вкладка Ілпк$ (рис. 6.20) содержит два списка — список полей отчета и базы 
данных АѵаіІаЫе Ріеігіз и список полей, по которым следует произвести свя¬ 
зывание отчета и подотчета РіеІ<1(8) іо Ііпк іо. После выбора поля отчета 
в нижнем левом списке выбора 8еІесі гіаіа іп «иЬгерогі Ьавегі оп Яеіё появля¬ 
ется список полей подотчета того же типа, что и выбранное поле основного 
отчета. Для связывания отчета и подотчета необходимо в список Ріе1<1($) іо 
Нпк іо ввести имя поля основного отчета, а в нижнем левом списке выбрать 
соответствующее поле подотчета. Если отчет и подотчет связаны, Сгу$1а1 
Керогіз 9 автоматически создает параметр и условие выборки по этому па¬ 
раметру, например: 

(Огйегз.СизСотег ГО} = {ЗРтГОизСотег.СизСотег ГО} 





146 


Гпава 6 


Іп$ег( ЗиЬіерогІ 


$иЬгеро« Нпк 


Рог^иЬгероЛ' | , 

- Сопіаіпн ВероЛ КеИ(а) Іо Кпк !о • 
бѵаіІаЫе РіеЙк 


Е Щ Сизіотеі 

аз Сизіотег 10 
оз Сизіотег СіеЛ Ю -Д 
ста Си$1отег Мате 
. со Сопіасі Ріг$1 Мате 
аэ СогЛасЛ Іа$1 Ыате V 

-I 1 >П 


Сшіотеі. Сироте* ір/іѳИ Ііпк- 
ЗиЫерсП дагатеіег (іеЙ (о и$е: 

{ ?РтСи$1отег.Си5(отег 10 


Ш 


3 


Ріеіф) Іо Ііпк Ьэ:. 


Си$1огпбг.СШотег 10 


3 


г; Беіесі ііаіа іп $иЫерсяІ ЬазесІ оп 
1 (іеН. '■ 

[сййотегІО 


3 


ОК 


СапсеІ 


Неір 


Рис. 6.20. Вкладка 1-іпкз диалогового окна Іпзегі ЗиЬгерогі 


Следовательно, при связывании отчета и подотчета данные подотчета 
фильтруются так, чтобы они соответствовали данным основного отчета. 

Для связывания можно использовать параметр, созданный в подотчете 
вручную (розд. 2.5). Все параметры подотчета доступны в списке выбора 

8иЬгерогі рагатеіег ПеІ(1 іо изе. 

Отчет и подотчет могут быть связаны и посредством формулы. Например, 
если поле отчета, по которому должно произойти связывание, — число 
(в примере — Сизіотег.Сизіотег Ш), а поле подотчета — строка, то в отчете 
можно создать формулу 

ТоТехС ( {СизТотег .СизСошег ГО} ,0 ) 

и переместить ее в список РіеМ(з) іо Ііпк іо. 

В основном отчете подотчет является перемещаемым и редактируемым объ¬ 
ектом. Для редактирования подотчета Сгузіаі Кероііз 9 создает дополнитель¬ 
ную вкладку, соответствующую вкладке Безіёп основного отчета, и имя 
вкладки соответствует имени подотчета. Подотчет может быть отредактиро¬ 
ван независимо от основного отчета, в частности опция 8еі Баіазоигсе 
Ьосаііоп, выбираемая командой меню БаіаЬазе | 8еі Оаіазоигсе Ьосаііоп, 
в основном отчете и в каждом подотчете имеет собственное значение. 

Для форматирования подотчета следует в основном отчете установить на 
нем указатель, щелкнуть правой кнопкой мыши и выполнить соответст¬ 
вующую команду контекстного меню: 

□ 8аѵе ЗиЬгерогі Аз — сохранение подотчета в отдельном файле грі; 
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□ СЬап§е 8иЪгерог1 Іллкв — изменение связывания подотчета; 

□ Е<Ш 8иЬгерог1 — переход в режим редактирования шаблона подотчета; 

□ Рогшаі ЗиЪгерогІ — вызов диалогового окна Рогтаі Егіііог для изменения 
визуальных свойств подотчета. 

Упражнение 6.6 

Используя в качестве источника данных таблицу Сивіотег, создайте отчет, 
содержащий диаграмму типа Ваг, показывающий продажи из поля Ьаві 
Ѵеаг'в 8аІев по всем штатам (регионам, поле Ке§іоп). В отчет включите толь¬ 
ко регионы Соединенных Штатов. Включите в основной отчет подотчет, 
содержащий диаграмму типа Ріе, показывающий продажи в пяти крупней¬ 
ших штатах. 

Для создания такого отчета необходимо: 

1. В основном отчете установить фильтр 

СошШгу із есзиаі Ъз "И5А" ; 

2. В основном отчете выполнить группирование по полю Ке§іоп; 

3. В секцию Керогі Неайег основного отчета вставить диаграмму типа Ваг, 
на вкладке Баіа выбрать тип Сгоир; 

4. Скрыть все секции основного отчета, кроме Керогі Неагіег и Керогі 
Рооіег; 

5. В секцию Керогі Рооіег основного отчета вставить подотчет; 

6. В подотчете установить фильтр 

СоигЩгу із е<зиа! Ьо "Ц8А"; 

7. В подотчете установить группировку Тор N по полю Кефоп; 

8. В секцию Керогі Неагіег подотчета вставить диаграмму типа Ріе (на 
вкладке Баіа выбрать тип Сгоир); 

9. Скрыть все секции подотчета, кроме Керогі Неайег. 

Основной отчет и подотчет не должны быть связаны. 

Данные могут быть переданы из основного отчета в подотчет и возвращены 
из подотчета с помощью переменных типа ВЬагесЗ. Для этого отчет и подот¬ 
чет должны содержать формулы с одной и той же переменной типа 81іагеб. 

Упражнение 6.7 

Рассмотрим пример передачи параметра из подотчета в основной отчет. 

1. Используя в качестве источника данных таблицу Сивіошег, создайте от¬ 
чет, включите в него поля Сивіошег №те и Сивіошег ГО. Создайте мно¬ 
жественные секции Оеіаіів а и ДеІаНв Ь. 
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2. В секцию Ве1аі1$ Ь внесите формулу 81іагес32: 

МЫ 1 еРг іп Ь іпдКесогсіз ; 

ЗЬагеЦ сиггепсуѴаг ЫѴ1; 

3. Используя в качестве источника данных таблицу Оггіегв, создайте подот¬ 
чет и включите в него поле Опіег$.Си$1:отег ГО. Свяжите отчет и подот¬ 
чет по полям Сизіотег. Сизіогаег ГО и Огйегз. Сизіотег ГО 

4. В секцию Керогі Рооіег подотчета внесите формулу 8Ьагей1 

ЗЬагей сиггепсуѴаг ЫѴ1 ; 

ЫѴ1 := Зит ({Огдегз.Огдег АтоипС}) 

5. Скройте все секции подотчета, кроме Керогі Рооіег. 

6. Вставьте подотчет в секцию Иеіаііз а. 

Обратите внимание, что формула 8Ьагеб2, использующая значение пере¬ 
менной из подотчета, расположена в секции, следующей за секцией, вклю¬ 
чающей подотчет. Подотчет должен выполняться ранее, чем вычисляется 
значение формулы, иначе будет передаваться неверное значение перемен¬ 
ной ЬІѴІ. 


6.7. Отчет на основе 
ОІ-АР-источников данных 

Эффективный анализ корпоративной информации является сложной зада¬ 
чей. Она усложняется еще и тем, что структура промышленных баз данных, 
как правило, оптимизируется для оперативной работы с данными и к дан¬ 
ным предъявляются требования непротиворечивости, целостности и отсут¬ 
ствия коллизий при выполнении операций редактирования — удаления 
и вставки данных. К сожалению, обеспечение этих требований путем нор¬ 
мализации схемы базы данных приводит к падению производительности 
при выполнении аналитических отчетов, а это затрудняет анализ информа¬ 
ции. Возможным решением проблемы является создание специализирован¬ 
ных баз данных, дополняющих оперативные реляционные. Базы данных, 
поддерживающие технологию оперативной аналитической обработки дан¬ 
ных (Опііпе Апаіуйсаі Ргосе5$іп§, ОЬАР), представляют собой один из типов 
таких специализированных баз данных. Технология ОЬАР является гибкой 
методикой анализа корпоративных данных. Сгу$1а1 К.ероі1$ 9 поддерживает 
работу с некоторыми ОЬАР-источниками данных и позволяет создавать от¬ 
четы на основе информации, хранящейся в этих базах данных. 

Обычно в отчетах Сгу$1а1 Кероі1$ 9 или электронных таблицах данные изо¬ 
бражаются в двумерном виде. По строкам и столбцам указывается, напри¬ 
мер, наименование товара и регион, а в ячейке таблицы приводится сумма 
продаж конкретного товара в конкретном регионе. С помощью двумерной 
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таблицы можно исследовать только два измерения, наименование товара и 
регион в данном примере. Если необходимо исследовать зависимость про¬ 
даж от периода времени, то придется вводить в отчет дополнительный па¬ 
раметр, например месяц, и использовать его как условие выборки данных. 
Тогда таблица будет представлять продажи различных товаров в разных ре¬ 
гионах, например, в январе. Если нужно рассмотреть, как продавались това¬ 
ры в феврале, необходимо вновь заполнить отчет данными с новым значе¬ 
нием параметра, что требует времени. Для анализа того, как продавались 
товары в одном регионе, но в разные периоды времени, необходимо создать 
новый отчет и заполнить его данными, что потребует дополнительных ре¬ 
сурсов. В ОЬАР-источнике данные логически представляются в виде много¬ 
мерного куба (рис. 6.21). 


Товары 



Рис. 6.21. Пример представления данных в виде трехмерного куба 


ОІАР-сервер позволяет представить данные в виде ш-мерного среза «-мерного 
куба с очень высокой производительностью. На рис. 6.21 показан двумер¬ 
ный срез трехмерного куба. Срез представляет продажи товаров в различных 
регионах, отфильтрованные по определенному периоду времени. ОЬАР- 
сервер обеспечивает высокую производительность при выполнении таких 
операций, как параллельный перенос среза — изменение периода времени, 
изменение плоскости среза — определение зависимости продажи товара от 
времени в конкретном регионе или продажи конкретного товара в регионах 
в разные периоды времени. 

Сгу$(а1 КероПд 9 позволяет создавать отчеты на основе данных из ОЬАР-кубов 
различных промышленных стандартов, а также комбинировать отчеты, соз¬ 
данные на основе данных из реляционных баз и из ОЕАР-кубов, например: 

□ создать стандартный отчет с использованием реляционной базы данных; 

□ создать ОЬАР-отчет, с использованием данных исключительно из куба; 

□ создать стандартный отчет с использованием реляционной базы данных 
и добавить к нему ОЬАР-отчет, основанный на кубе; 

□ создать несколько различных ОЕАР-отчетов с использованием одного 
или нескольких кубов. 
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Отчеты Сгукіаі Керогіз 9 на основе ОІЛР-кубов содержат специальный объ¬ 
ект — ОІЛР §гій, который по структуре аналогичен объекту Сго$$-ТаЪ мат¬ 
ричного отчета. 

Создать ОІАР-отчет можно, выбрав в диалоговом окне Сгувіаі Кероіів 
Саііегу (рис. 2.1) пункт ОІЛР. Появляется мастер отчетов ОІЛР Керогі 
Сгеайоп ѴѴіхагй, который содержит несколько последовательно открываю¬ 
щихся окон, позволяющих шаг за шагом создать отчет. 

Первое окно мастера ОІЛР Баіа (рис. 6.22) предназначено для выбора ис¬ 
точника данных для отчета. Предварительно должно быть установлено кли¬ 
ентское программное обеспечение выбранного ОІЛР-сервера. 



Рис. 6.22. Окно ОЦ^Р йа*а мастера ОЦАР Нерогі Сгеаііоп ѴѴігагсІ 


Источником данных может быть ОІЛР-сервер или файл САК, созданный 
в среде СгувіаІ Апа1у§і§ Ргоіеввіопаі. Для выбора файла САК следует щелк¬ 
нуть на кнопке 8еІесі САК Рііе. Для выбора в качестве источника данных 
ОІЛР-сервера следует щелкнуть на кнопке 8еІесі СиЬе. Появляется диалого¬ 
вое окно ТЪе Сгувіаі ОІЛР Соппесііоп Вго\ѵвег (рис. 6.23). 
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Рис. 6.23. Диалоговое окно Сгузіаі ОІАР Соппесііоп Вгоѵѵаег 
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Рис. 6.24. Диалоговое окно Ыеѵѵ Зегѵег 


Для создания нового источника данных следует щелкнуть на кнопке Айй 
Зегѵег. Появляется диалоговое окно №\ѵ Зегѵег (рис. 6.24), позволяющее 
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выбрать опции сеанса связи с ОЬАР-сервером. В верхней части диалогового 
окна находится раскрывающийся список 8егѵег Туре с типами связи с сер¬ 
вером. Для большинства серверов используется МісгозоВ ОЬЕ ЭВ Ргоѵібег 
Гог ОЬАР $егѵісе$. Для сервера Но1о$ Уѵе $егѵег, опция Ноіоз НБ8 СиЪез, 
используется Ореп Сотропепі АгсйіІесШге Гог ОТАР (ОСА). Кроме того, 
возможен прямой доступ к серверам ІВМ ОВ2 ОЬАР 8егѵег и Нурегіоп Е$з- 
Ьа$е. В поле Сарйоп указывается имя сервера, который будет использоваться 
для отчета, это поле обязательно для заполнения. Содержимое нижней час¬ 
ти диалогового окна — 8егѵег Ор(іоп$ — зависит от выбранного типа связи. 
Для всех типов кроме Но1о$ Уѵе $егѵег следует указать имя сервера (8егѵег), 
имя пользователя (Изег N 3016 ) и пароль (Ракзѵѵогсі). Для Но1о$ Уѵе Зегѵег 
необходимо указать имя файла типа НЭ8. После щелчка на кнопке ОК диа¬ 
логовое окно N6» 8егѵег закрывается и в списке окна СгукГаІ ОІАР Соппесйоп 
Вгоѵгаег появляется новый ОЬАР-источник данных (рис. 6.23). Если в вы¬ 
бранной базе данных содержится более одного куба, то в раскрывающемся 
списке следует выбрать куб, по которому будет создаваться отчет. Для выбо¬ 
ра источника следует переместить указатель на строку в списке ОЬАР- 
источников данных и щелкнуть на кнопке Ореп. 
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Рис. 6.25. Окно Воѵѵв/Соіитпа мастера СЛАР Верогі Сгеаііоп ѴѴігаггі 
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Щелчок на кнопке N6x1 (Далее) открывает второе окно мастера ОЬАР 
Керогі Сгеаііоп ѴѴігаггі-Еоѵв/СоІитпв (рис. 6.25), позволяющее выбрать из¬ 
мерение или измерения куба, которые будут использоваться в качестве 
строк и столбцов отчета. 

Доступные измерения куба показываются в списке Оітепвіопв. Чтобы ис¬ 
пользовать измерение в качестве строки или столбца, необходимо перемес¬ 
тить указатель на строку в списке Оітепвіопв и щелкнуть на кнопке > слева 
от списка Со1шпп8 или Коѵѵв В списки Ко\ѵ8 и Со!шпп8 можно добавлять 
более одного измерения, в этом случае они будут сгруппированы иерархиче¬ 
ски, так же как группируются множественные строки и колонки в матрич¬ 
ном отчете. Для построения иерархии измерения должны быть перечислены 
в правильном порядке, например, сначала страна, затем — регион и по¬ 
том — город. Если размерности внесены в списки Ко\ѵ,8 или Соіитпв 
в неверном порядке, то можно просто перетащить их на правильные пози¬ 
ции, либо выделить измерение и переместить его на правильное положение 
с помощью клавиш "вверх" и "вниз". Для удаления измерения необходимо 
переместить указатель на строку в списке Кснѵ8 или СоІшпп8 на соответст¬ 
вующее измерение и щелкнуть на кнопке <. 

Измерения куба, на основе которого создается отчет, могут составлять 
много уровней, содержащих детальную информацию более низкого уровня и 
образующих иерархию данных в измерении. По умолчанию Сгувіаі Верогів 9 
показывает только самый верхний уровень иерархии. Для включения других 
уровней следует щелкнуть на кнопке 8еІесі Ко>ѵ МетЬегв или 8е1есі Соіішіп 
МетЬегв. Появляется диалоговое окно МетЬег 8е1есіог (рис. 6.26) с древо¬ 
видным списком значений измерения. Для включения значения на любом 
уровне иерархии необходимо выбрать его в списке. Если в списке выбрано 
хотя бы одно значение, в отчет будет включен соответствующий уровень. 
Для облегчения работы со списком, который может быть весьма обширным, 
в верхней части диалогового окна МетЬег Зеіесіог находится раскрываю¬ 
щийся список 8е1есі, содержащий набор действий со списком значений. 
Например, можно выбрать все значения списка (8еІесі АН МетЬегв) или 
отменить <выбор (8е1есі ГЧопе), инвертировать выбор (Іпѵегі 8еІесІіоп), вы¬ 
брать значение верхнего (Агігі Рагепі іо Зеіесііоп) или нижнего (Асііі СЬіІйгеп 
іо 8е1есііоп) уровня и т. д. 

Третье окно мастера ОІАР Керогі Сгеаііоп ѴѴігагй — 8Іісе/Ра§е (рис. 6.27) 
позволяет включить в отчет те измерения куба, которые не отображаются 
в качестве строк или столбцов. В левом списке окна 81ісе показываются из¬ 
мерения, не выбранные в качестве строк или столбцов, в правом (Ра§е) — 
измерения, на основе которых отчет будет разбит на группы. Щелчок на 
кнопке 8е1есі 8Нсе вызывает диалоговое окно МетЬег 8еІесіог, где можно 
указать одно значение измерения, которое войдет в отчет. Данные, соответ¬ 
ствующие прочим значениям, в отчет не войдут, другими словами, здесь 
с помощью МетЬег Зеіесіог можно установить фильтр по измерениям куба, 
не выбранным в качестве строк или столбцов. 






іМопіЫу = Ѵеаг Тоіаі] 


Эгад а <Іпіатіог> Ьіо Йі Вй Ьох апсізеіесі 


I ^ 1 . ’ А 'Ліі 


Цгк Іо Вагатеіеі: 


1 0 (НАР Нерон Сгеаііоп Ѵ/ігаггі 


БІісе/Раде 

й 


Рис. 6.27. Окно ЗІісе/Раде мастера (ИАР Иероіі Сгеаііоп ѴѴігагсі 


Список Ра§е позволяет организовать группирование по измерениям куба. 
Для внесения измерения в список Ра§е, необходимо переместить указатель 
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на строку в списке 81ісе и щелкнуть на кнопке > слева от списка Ра§е. 
Появляется диалоговое окно МетЬег 8е1есіог (справа на рис. 6.28). В списке 
окна МетЬег 8еІесіог показывается иерархия уровней выбранного измере¬ 
ния. По умолчанию в отчет включается только один верхний уровень. При 
этом в отчете будет существовать только один объект ОІАР §гій. Для вклю¬ 
чения нижних уровней следует раскрыть иерархический список и отметить 
в нем значения, например, на рис. 6.28 для измерения МопіЫу отмечен уро¬ 
вень 0 (Уеаг Тоіаі) и несколько значений уровня 1 (Іап, РеЬ, Маг и Арг). 
В этом случае в отчете выполняется группирование, во внешнюю группу 
включается объект ОІАР §гЫ уровня 0, во внутреннюю группу — объект 
ОІАР з>п<1 уровня 1, причем во внутренней группе будут показаны только те 
ОІАР §гі<1 уровня 1, которые соответствуют выбранным в списке окна 
МетЬег 8еІесіог значениям. На рис. 6.28 показан вид такого отчета в режиме 
Ве$і{*п в центре и Ргеѵіем справа. Диалоговое окно МетЬег 8еІесіог можно 
вызвать для изменения выбранных значений измерения, щелкнув на кнопке 
8е1есі Ра§е ѴаІие$ в окне 8Іісе/Ра§е мастера ОІАР Керогі Сгеаііоп ѴУігаггі. 




Рис. 6.28. Группирование данных в отчете на основе ОЦ\Р-источников данных 


Кнопки СгеаІе/ЕсІіІ и Оеіеіе в группе Ілпк іо Рагатеіег позволяют создавать 
и удалять параметры для выборки и группировки по измерениям куба. 
Щелчок на кнопке Сгеаіе/Егііі вызывает диалоговое окно Сгеаіе Рагатеіег 
РіеМ (рис. 2.21), позволяющее создать новый параметр. Создание и исполь¬ 
зование параметров было рассмотрено в разд. 2.5. 

Окна СНагі и 8іу1е мастера ОІАР Керогі Сгеаііоп ѴѴігагй аналогичны окнам 
СНагі и Сгігі 8іу1е мастера Сгозз-ТаЬ Керогі Сгеаііоп \Ѵігагй (рис. 6.10 
и 6.11) Они предназначены для создания диаграммы на основе данных объ¬ 
екта ОІАР §гМ и выбора одного из предопределенных стилей этого объекта. 
Щелчок на кнопке РіішЬ (Готово) закрывает мастер ОІАР Керогі Сгеаііоп 
\Ѵігаг<1 и открывает вновь созданный отчет. 

Создать отчет на основе ОЬАР-источников данных можно, также вставив 
в стандартный отчет объект ОІАР-§гі(1 с помощью команды меню Іпзегі/ 


6 Зак. 1021 
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ОІАР тй или кнопки панели инструментов для вставки объектов в отчет, 
см. табл. 1.3. Появляется диалоговое окно ОІАР Ехрегі (рис. 6.29). Это 
же окно используется и для редактирования созданного объекта 
ОІАР-§гіё. Чтобы инициировать редактирование, следует щелкнуть на ле¬ 
вом верхнем углу ОІАР-§гі(і и в контекстном меню выполнить команду 
ОІАР Ехрегі. 


ОІАР Ехрегі 


:с , ОГАВСаІа.) ;(|ом$/ЕЫитга ] Зкй/Рада | Зіуіе ••• 
... {ОрЬопаЦ Сиротке Нте дпЛ Йуіа 


МосЙу ой*» орііот гіеяіеД : 


я;:А?№’а^'0( сойдапде 

і Щттшшщ- ^гдгг ■ ---ѵ-..™.,.... 

_ 

8 •« , ? і іалтенд г лі і • 

<Х-X'»'-":ѵ;< 'А> . ГЬ'лГч'Уѵ-^^аѴ»** '.V, Л-.- • 

- к ' * • , 

Я<аж ' у - 


Сизіотег, ЬеѵеІ О 


’г-.*-2у Т;;;ѵ 


* ' Ѵ -Ч ѵ Ах. ' 

- — - ——* 




іаі 


■ &аскд«^ісіеок»я?у:|а Сийот 3 Ш0ШжМ ' ІРгогіисиеѵеІ С( |® 

-а - і■■• р ...»..-А % 



„ -ОК.-^^СапсвІ.;-:}: 


Рис. 6.29. Вкладка Сизіотіге ЗІуІе диалогового окна ОЪАР Ехрегі 


Вкладки ОІАР Наіа, Штз/Соішппз, 81ісе/Ра§е и 81у1е диалогового окна 
ОІАР Ехрегі аналогичны окнам ОІАР Баіа, Коѵѵв/Соішшіз, 81ісе/Ра§е и 
8іу1е мастера ОІАР Керогі Сгеаііоп \Ѵіхагй (см. рис. 6.22, 6.25 и 6.27). 

Вкладка ОІАР Ваіа позволяет выбрать ОІАР-источник данных. Кнопка 
8е1есІ СиЬе вызывает диалоговое окно Сгузіаі ОІАР Соппесііоп Вго\ѵкег 
(рис. 6.23), в котором следует указать ОІАР-источник данных. Вкладка 
Коѵѵз/Соіитш позволяет выбрать измерение или измерения куба, которые 
будут использоваться в качестве строк и столбцов объекта ОІАР-§гій. 
Вкладка 81ісе/Ра§е позволяет выбрать и. сгруппировать данные отчета. 

На вкладке ЬаЬе1$ (рис. 6.30) можно выбрать метки к объектам ОІАР-§гій из 
значений измерений, которые не были выбраны ранее в качестве строк или 
столбцов. 
































Сложное форматирование и специальные типы отчетов 


157 



(НАР ЕхрегІ 


,Моп(Ыу 


01АР0а(а| Воѵй/Соіитга | 5Іісе^Раде-| 5іуІе ] Сц5Іоткв5|уІе ЦЭД* | 

. Спооге Ида)Іо гкріау іаЬек ?ог іИб.йтепяопг Йѵаі :аге тюІогѵ.ІЬе дяі 
й',;-' ЦпІДЬвЫРітегіаогіа : ЬаЬеІей Рішеічеюте 


<- ІаЬеІ Зрасіпа---— - г— 

' ѴеіЬсаІдар | 0 - 18 ст 

Нолгста! дар [сіЛ 8 ст 


Г" Овріау сіітепяоп пате 


Рис. 6.30. Вкладка ЦаЬеІз диалогового окна ОЬАР ЕхрегІ 

Вкладка Сикіотіге 8Гу1е (рис. 6.29) позволяет настроить формат создаваемых 
объектов ОІАР-§гігі. Эта вкладка аналогична соответствующей вкладке ре¬ 
дактирования матричного отчета. В верхней части вкладки Сикіотке 8іу1е 
расположены окна Ко\ѵз и Соіитпз. Одновременно можно выбрать только 
один объект (строку или столбец объекта ОІАР-§гі<1) в одном из двух окон. 
Именно для этого объекта можно установить свойства с помощью элемен¬ 
тов управления, расположенных в нижней части вкладки. В табл. 6.4 приве¬ 
дены опции форматирования строк и столбцов объекта ОІАР-§гій, доступ¬ 
ные на вкладке Сизіотіге 8іу1е. 

Таблица 6.4. Опции форматирования строк и колонок ОіАР-дгШ 

Опция Описание опции 

АІіаз Гог Рогтиіаз Используется для ссылки на целую строку или столбец 

при выполнении условного форматирования в объекте 

ОІ-АР-дгісІ 

ВаскдгоипсІ Соіог Устанавливает цвет фона для строки или столбца 

ЗНоѵѵ СеІІ Магдіпз Окружает ячейки свободным пространством со всех 

сторон. Отключение этой опции позволяет размещать 
ячейки более компактно 
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Таблица 6.4 (окончание) 

Опция 

Описание опции 

Іпсіепі Нош (.аЬеІз 

Выбор этой опции приводит к отступу подписи (ІаЬеІ) 
выбранной строки от левого края объекта ОІ.АР-дгі<± 
Величина отступа строки задается в поле снизу от окна 
выбора Іпоіепі Нош ЬаЬеІз 

РогтаКЗгісі Іапез 

Вызывает диалоговое окно Рогтаі СгісІ 1_іпез, которое 
предназначено для задания формата линий сетки 
в объекте ОІ_АР-дгісІ 

Кеер Соіитпз ТодеіНег 

Защищает столбцы от разбиения, когда распечатывае¬ 
мая таблица превосходит по ширине страницу и табли¬ 
ца объекта ОІАР-дгісі должна быть распечатана на двух 
или более страницах 

Нереаі Нош 1_аЬеІз 

При выборе Кеер Соіитпз ТодеіИег повторяет метки 
строки, если ширина объекта 01_АР-дгігі превышает 
ширину страницы 

Зирргезз Етріу Ношз 

Скрывает строки, не содержащие данных 

Зирргезз Етріу Соіитпз 

Скрывает столбцы, не содержащие данных 


Для форматирования готового объекта ОІАР §гігі следует, щелкнув в левой 
верхней части правой кнопкой мыши, выполнить команду контекстного 
меню Рогтаі ОІАР §гій. 

После внесения в секцию отчета, на вкладке Ое$і§п объект ОІАР §гій вы¬ 
глядит как набор дочерних полей. Каждое дочернее поле может быть от¬ 
форматировано индивидуально, в том числе по условию, как обычное поле 
отчета. Для форматирования поля следует щелкнуть по нему правой кноп¬ 
кой мыши и выполнить команду контекстного меню Рогтаі Ріеігі. Размер 
каждого дочернего объекта можно изменить так же, как обычного поля. 
Можно выделить несколько объектов, а затем отформатировать их все одно¬ 
временно. Для условного форматирования используется диалоговое окно 
Ні§Мі§ііНп§ ЕхреіЧ, вызываемое выполнением команды Ні§ііІі§М:іп§ Ехрегі 
контекстного меню, или с помощью формулы. Формула создается щелчком 
на кнопке условного форматирования в диалоге Гогот! Егіііог. 

Данные, хранящиеся в ОІАР-базе данных, можно использовать в основном 
отчете. Для этого в списке источников данных нужно выбрать источник 
ОБВС или ОБЕ БВ в разделе Сгеаіе Соппесйоп списка АѵаіІаЫе Баіа 
8оигсе§ окна Оаіа мастера ЗДапЛагй Керой Сгеайоп \Ѵігагй. 

Иногда возникает необходимость переопределить источник данных уже соз¬ 
данного объекта ОЬАР-§гій. Для этого необходимо выбрать пункт меню Ба- 

ІаЬазе/Зеі ОІАР СиЬе Ьосаііоп. В появляющемся диалоге 8еі ОІАР СчЪе 

Босаііоп следует выбрать новый куб ОІАР. 
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Упражнение 6.8 

Создайте отчет на основе ОІАР-куба. 

Для создания такого отчета необходимо: 

1. Щелкнуть на кнопке создания нового отчета. 

2. Выбрать в диалоговом окне Сгу$Ы Керогік СаІІегу (рис. 2.1) пункт ОІАР. 

3. В окне ОІАР Баіа мастера ОІАР КероіЧ Сгеаііоп \Ѵігагй щелкнуть на 
кнопке 8еІесІ СиЬе. 

4. В диалоговом окне Сгувіаі ОІАР Соппесііоп Вго\ѵ$ег (рис. 6.23) щелкнуть 
на кнопке Айсі 8егѵег. 

5. В диалоговом окне 8егѵег внести имя источника в поле Сарйоп, 
в качестве типа источника данных выбрать Ноіоз НОС СиЬе, щелкнуть на 
кнопке справа от поля НОС Рііе и найти файл Рго§гат Рі1е5\Сгуйа1 
Оесі5іоп5\Сіу5Га1 КероПз 9\§атр1е$\Еп\0аіаЬа$е5\01ар Оа1а\ ХТКЕМЕ.НОС, 
затем щелкнуть на кнопке ОК. 


01. АР сНагІ 



Ѵеаг Тоіаі 



АН Ргосіисіе 







Моггіе 

N іс гое 

Рареі 

Ротео 

СА 

401 785,03 

35 537,83 

23 533,60 

24 809,20 


ГЬ 

165 841,83 

26 173,96 

2 687,31 

14 477,66 

1 702,60 

N3 

88 054,79 

10 400,94 

6 927,05 

7 731,84 


ТХ 

82 581,82 

23 941,54 

5119,20 

1312,11 

2 497,05 


Рис. 6.31. Пример ОЬАР-отчета с диаграммой 
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6. В диалоговом окне СгузЫ ОІАР Соппесііоп Вічшзег переместить указа¬ 
тель на строку в списке ОЬАР-источников данных и щелкнуть на кноп¬ 
ке Ореп. 

7. В окне Ко\ѵз/Со1итпз мастера ОІАР Керогі Сгеаііоп \Ѵігаг<1 внести в ка¬ 
честве столбца Ргойисі и в качестве строк Сизіошег. 

8 . Щелкнув на кнопке 8еІесІ Ктѵз (Соіиптз) МетЬегз в диалоговом окне 
МетЬег 8е!есІог, для размерностей Ргойисі выбрать значения Моггіе, 
№сгоз, Кареі, Котео. Для размерности Сизіотег выбрать значения N1, 
ТХ, РЬ и СА. 

9. Щелкнуть на кнопке Ріпізіі (Готово). 

10. Щелкнуть в левом верхнем углу объекта ОІАР-§гі<1 и выполнить коман¬ 
ду меню Іпзегі СЬагГ. 

11. На вкладке Туре диалогового окна СЬагі Ехрегі выбрать тип отчета ЗБ 
Кізег и на вкладке Баіа установить Оп С1іап§е оГ = Ргобисі, Ьеѵеі 1 и 
8 иЬбіѵібеё Ьу = Сизіотег Ьеѵеі 1. 

Полученная диаграмма показана на рис. 6.31. 




Глава 7 


Связь с базами данных 


7.1. Связывание таблиц 

Большинство отчетов формируется из данных, находящихся в различных 
таблицах. Для удобства разработчиков в Сгу$іа1 Керогй 9 включен мастер, 
который позволяет задать параметры связывания таблиц. В случае использо¬ 
вания какого-либо эксперта, позволяющего создать отчет, при выборе 
нескольких таблиц в диалоговом окне Баіа (Данные) автоматически на сле¬ 
дующем этапе открывается окно Упк (Связывание), показанное на рис. 7.1. 
При работе с уже созданным отчетом ту же самую функцию по настройке 
параметров работы с таблицами базы данных выполняет мастер под назва¬ 
нием ОаіаЬазе Ехрегі (Эксперт базы данных), который можно вызвать, на¬ 
жав на кнопку □?_! . Того же самого результата можно добиться при исполь¬ 
зовании команды меню ОаіаЬазе | Ба<аЪа$е Ехрегі Элементы диалого¬ 
вого окна ОаіаЬазе Ехрегі (Эксперт базы данных) показаны на рис. 7.2 и 7.3. 

В зависимости от того, какой тип источника данных используется при фор¬ 
мировании отчета, внешний вид таблиц, отображенных в окне Упк или на 
вкладке Упк$ в окне ОаіаЬазе Ехрегі, может незначительно измениться. При 
работе с настольными базами данных, связь с которыми осуществляется на¬ 
прямую, некоторые колонки в таблицах помечены цветовыми метками так, 
как это показано на рис. 7.4. Цветовые метки выделяют проиндексирован¬ 
ные колонки. Цвет метки определяет тип индекса. Легенда цветов для про¬ 
индексированных колонок показана на рис. 7.5. 

При работе с реляционными источниками данных или в случае использова¬ 
ния СШВС, АБО, БАО и т. п. для подключения к базе данных, выделение 
цветовыми метками проиндексированных колонок не происходит. Данный 
вариант отображен на рис. 7.3. 





Рис- 7.1. Диалоговое окно Ыпк, отображаемое в момент построения отчета 
с помощью какого-либо эксперта 
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Рис. 7.2. Диалоговое окно йаІаЬазе Ехрегі. Вкладка выбора таблиц, 
используемых для формирования отчета 
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Рис. 7.3. Диалоговое окно ОаіаЬазе ЕхреП. 
Вкладка настройки взаимосвязи между таблицами 
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Рис. 7.4. Диалоговое окно ОаіаЬаве Ехрегі. Вкладка настройки взаимосвязи 
между таблицами из настольного источника данных 
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Рис. 7.5. Легенда цветовых меток, используемых 
при отображеніе проиндексированных колонок 


Примечание 


Сгузіаі Перогіз версии 9.Х отличается от более ранних версий своими возмож¬ 
ностями для работы с базами данных. В данной версии генератора отчетов 
принцип работы с различными типами источников данных абсолютно одинаков. 
В то же время Сгузіаі Нерогіз версий 8.5 и ниже различает типы источников 
данных и требует выполнения определенных условий при связывании таблиц. 
Подробнее о требованиях, предъявляемых к связыванию таблиц в Сгузіаі 
Перогіз 8.Х, можно узнать в книге "Введение в Сгузіаі Перогіз", Маклаков С., 
Матвеев Д. Интерфейс-Пресс. Богородский печатник. 


Окно Ііпк и вкладка Іллкз в окне ИаіаЬазе Ехрегі имеет следующие элемен¬ 
ты управления: 

□ Аиіо-Аггагще — выравнивание таблиц; 

□ Аиіо-Ьіпк ТаЫев — группа элементов, позволяющих выполнить автомати¬ 
ческое связывание таблиц по выбранному условию: 

• Ву №те — связать таблицы по одноименным колонка; 

• Ву Кеу — связать таблицы по ключевым колонкам; 

• Аиіо-Ьіпк — выполнить операцию связывания; 
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□ Опіег-Ілпкз — вызывает диалоговое окно (см. рис. 7.6), позволяющее на¬ 
строить порядок следования связей; 

□ СІеаг Упк« — удаление всех связей, установленных автоматически или 
вручную; 

□ Беіеіе Ыпк — удаление выбранной связи; 

□ Ьіпк Орііоп8 — просмотр свойств связи между таблицами. Диалоговое 
окно, позволяющее просмотреть и настроить характеристики связи меж¬ 
ду таблицами, показано на рис. 7.7; 

□ Гіміех Ье^ешІ — вызов легенды цветовых меток, используемых при ото¬ 
бражении индексированных колонок. Легенда показана на рис. 7.5. 


Аггапде (Не Ііпкз іп (Не огсіег уои юоиісі Ііке (Нет (о Ье ргосездесІ 
(ТИе отгіёг тау аКес( (Не іезйКіпд <іа(а $е(.) 


3* ііпк огсіегіпд і$ еп*огсесі 


Сиа(отег.Сиз(отег Ю •■> 0гс1ег$.Си$(отег 10 


0Мег$.0ісІег Ю -•> 0гсіег5_0е(аіІ 0 гсіег Ю 
0гс1еі2_0е(аіІ.Ргосіис( Ю ••> Ргсхіис(.Рго(іис( Ю 


0К 


СапсеІ 


Неір 


Рис. 7.6. Диалоговое окно Огсіег Ипкз, позволяющее установить 
порядок следования связей 


В этом окне настроек имеется возможность установки предписанного 
порядка следования связей. Для этого необходимо установить флаг Ьіпк 
Огс1егіп§ і$ епГогсегі (Предопределенный порядок связывания). Также суще¬ 
ствует возможность изменения заданного порядка. Это достигается нажати¬ 
ем на кнопки 1 ж тг| после установки фокуса на соответствующую связь. 

В данном окне отображена информация о связи в формате <имя таблицы №і>. 
<Имя ключевой колонки> -> <Имя таблицы №2>.<Имя ключевой колонки> И две 

группы параметров, позволяющие изменить установки, заданные по умол¬ 
чанию, на те, которые требуются для более правильной обработки данных 
в отчете. В последующих разделах этой главы все параметры данного окна 
будут рассмотрены подробно. 

Кроме кнопок имеется возможность выполнения настроек с помощью кон¬ 
текстного меню, которое вызывается щелчком правой клавиши мыши 
на поле в таблице или на связи. Для поля будет вызвано меню, показанное 
на рис. 7.8, а для связи будет показано меню, представленное на рис. 7.9. 
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Рис. 7.7. Окно Упк Орбопз, позволяющее просмотреть 
и настроить параметры связи между таблицами 


Зголіе Р еИ 

- ЕхІёгпаІІгхіехез,.. ‘' і 
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Рис. 7.8. Контекстное меню, вызываемое 
для выбранного поля в таблице 

Команды этого меню предназначены для выполнения следующих задач: 

□ Вічт$е Ріеігі — просмотр данных, сохраненных в поле; 

□ ЕхіегпаІ Іпгіехе* — вызов диалогового окна, которое позволяет добавить 
внешние индексы, пункт меню доступен только для с!Ва$е; 

□ СапсеІ Мепи — закрытие контекстного меню. 


ЧсипкОрйогв... 
ОеІеСе Цпк 
Кеѵегзе Цпк 
Кетоѵе АІ! ипк5 
СапсеІ Мепи 


Рис. 7.9. Контекстное меню, вызываемое 
для выбранной связи между таблицами 

Пункты данного меню частично дублируют, а частично дополняют функ¬ 
циональность, предоставляемую кнопками: 

□ Упк Орііоп8 — просмотр свойств связи между таблицами. Диалоговое 
окно, позволяющее просмотреть и настроить характеристики связи меж¬ 
ду таблицами, показано на рис. 7.7; 
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□ Беіеіе Ілпк — удаление выбранной связи; 

□ Кеѵегее Ілпк — изменение статуса связываемых таблиц. Дочерняя таблица 
трансформируется в родительскую и наоборот. Данная операция влияет 
только на работу отчета, на уровне связей в базе данных ничего не меня¬ 
ется; 

□ Кетоѵе АН Ілпкз — удаление всех связей в окне Ілпк или на вкладке 

Ілпк$; 

□ Сапсеі Мепи — закрытие контекстного меню. 

Упражнение 7.1 

1. Создайте отчет, использующий в качестве источника данных несколько 
таблиц, и посмотрите результаты связывания в окне Ілпк или БаІаЬазе 
ЕхрегГ. 

2. Посмотрите свойства связей, используя меню и двойной щелчок мыши. 

7.2. Доступ к источникам данных 

Способы доступа к данным в Сгу$іа1 К.ероі1$ 9 можно разбить на пять кате¬ 
горий: 

1. Прямой доступ к данным. 

2. Доступ с использованием СЮВС. 

3. Доступ с использованием ОЕЕ ОВ. 

4. Доступ посредством файлов Сгу$са1 Пе$і§пег. 

5. Доступ посредством файлов Сгузіаі Оісііопагу. 

Для доступа к каждому типу данных используется определенный набор биб¬ 
лиотек и другие, необходимые для доступа файлы. 

В текущей версии Сгу$іа1 Керогіз предусмотрен прямой доступ к следующим 
источникам данных: 

□ Ассе$$ 7, 8, 2000; 

□ АСТ! 3, 4; 

□ Вігіеѵе; 

□ Сііррег; 

□ ЭВ2; 

□ 6ВА5Е ІІІ+, IV, для \Ѵігкіо\у$ и Ѵі$иа1 бВаде; 

□ ЕхсЬагще/ОиІІоок; 

□ РохРго 2.5 и более ранние версии; 
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□ ІпГогтіх; 

□ Ьосаі Рііе 8у$іет; 

□ ЬоШ$ Оотіпо; 

□ МІСГ 080 Й ІІ8/Ргоху Ьо§ Рііе; 

□ N1 ЕѵепС І.о§; 

□ Огасіе 7, 8.Х, 9.Х; 

□ Рагасіох; 

□ ЗуЬазе Асіарсіѵе 8егѵег; 

□ \ѴеЬ Ео§ Рі1е$. 

Совместно с Сгу$Ш1 К.ероіі$ 9 поставляется набор СЮВС-драйверов, которые 
можно выбрать в момент установки пакета и использовать в дальнейшем 
для работы. Кроме того, все СЮВС-драйверы, которые были установлены на 
компьютер ранее или потом, можно также использовать в Сгу$іа1 Керогіз 9. 

К поставляемым совместно с Сгуяаі ВероПз 9 библиотекам относятся: 

□ Кеяшгеб Кітііте Рі1е$; 

□ Ассе$$ 7.0 апсі АЬоѵе; 

□ А8СІІ Техі; 

□ ОВ2/2; 

□ Ехсеі; 

□ ІпГогтіх; 

□ ЕоШ$ Оотіпо; 

□ МісгозоЛ 8Е>Ь 8егѵег; 

□ Огасіе; 

□ Реор1е8оВ; 

□ 8уЬа$е Абарііѵе 8егѵег; 

□ Ѵі$иа1 РохРго; 

□ хмь. 

Наличие механизма ОЬЕ БВ позволяет обратиться к любым источникам 
данных, для которых есть ОЕЕ ЭВ-провайдер или СШВС-драйвер. 

Настроить источник (ЮВС можно с помощью стандартных средств опера¬ 
ционной системы. Учитывая то, что Сгузіаі Кероііз 9 является 32-разрядной 
программой и работает под управлением Шіпс1о\ѵ$ 9Х, Шіпбо\ѵ$ ЫТ или 
\Уіп<1о\ѵ$ 2000, программа настройки СЮВС для всех возможных вариантов 
одна и та же. Для вызова программы администрирования СШВС-драйверов 
можно в командном режиме запустить программу СЮВСА032.ЕХЕ или же, 
открыв окно Контрольная панель (СопігоІ Рапеі), выбрать пиктограмму 
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ОІ)ВС-источники данных (ОВВС Баіа Боигсез). Используя возможности 
Администратора источников данных ОБВС, можно добавить и настроить лю¬ 
бое количество источников, необходимых для работы. Подробнее о на¬ 
стройке конкретного (ЮВС-соединения можно прочитать в НЕЬР-файлах, 
устанавливаемых совместно с драйвером. Также информацию можно полу¬ 
чить в справке по СЮВС, находящейся в составе НЕБР по \Ѵіпс1о\ѵ$. 

Механизмы использования файлов Сгузіаі 8()Б Безщпег и Сгузіаі Оісііопагу 
предусматривают наличие файлов, созданных с помощью компонент Сгузіаі 
8()Б Эезщпег и Сгузіаі Оісііопагу, которые входят в Сгузіаі Керогіз, версий 
8 .Х и младше. Подробное описание процесса создания таких файлов и спо¬ 
собов их использования предоставлено в книге "Введение в Сгузіаі Керогіз", 
Маклаков С., Матвеев Д. Интерфейс-Пресс. Богородский печатник. 

Упражнение 7.2 

1. Создайте отчет, который работает с реляционной базой данных за счет 
прямого подключения. Например, с Огасіе. 

2. Настройте ООВС-драйвер с помощью Администратора источников данных 
ОБВС и создайте отчет в Сгузіаі КероПз 9 с использованием этого драй¬ 
вера. 

3. Создайте отчет, используя какой-либо из механизмов ОБЕ БВ. 


7.3. Настройка параметров Сгузіаі Рерогіз 9 
для работы с базами данных 

Помимо параметров, которые можно настроить в окнах Біпк и БаІаЬазс 
Ехрегі, существует также возможность определить ряд характеристик, кото¬ 
рые будут использованы на уровне всех создаваемых отчетов. Для того что¬ 
бы настроить эти параметры, необходимо вызвать диалоговое окно Орііопз 
командой меню Рііе | Орііопз и перейти на вкладку ОаІаЬазе так, как это 
показано на рис. 7.10. Можно также в диалоговом окне Баіа, вызвав щелч¬ 
ком по правой клавише мыши меню, изображенное на рис. 7.11, выбрать 
пункт Орііопз. При этом появится окно Орііопз, которое по своим характе¬ 
ристикам совпадает с вкладкой, изображенной на рис. 7.10. Внешний вид 
окна Орііопз представлен на рис. 7.12. 

Элементы контроля в данном окне, позволяющие выполнять настройку, 
разбиты на две группы: 

□ Ехріогег Орііопз (Опции выборки) — параметры выборки данных; 

□ Агіѵапсей Орііопз (Дополнительные опции) — расширенные возмож¬ 
ности. 
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Рис. 7.10. Диалоговое окно Орііопв 



Рис. 7.11. Контекстное меню, вызываемое 
в окне Упк или ОаіаЬаее Ехреіі 


Группа Ехріогег Орііопз содержит элементы управления, которые могут 
обеспечить более удобную работу с базами данных в момент создания отче¬ 
та. Эта группа разделена на подгруппы: 

□ 8Н<№; 

□ Ілзі ТаЫез апгі РіеМз Ьу; 

□ 8огйп§. 
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Подгруппа 8Ііо\ѵ (Показывать) включает в себя следующие элементы кон¬ 
троля: 

□ ТаЫе$ — если сделать активным данный параметр, то в отчете можно бу¬ 
дет использовать данные из таблиц; 

□ Ѵіе\ѵ$ — если сделать активным данный параметр, то в отчете можно бу¬ 
дет использовать данные из представлений; 

□ Зувіет ТаЫе$ — если сделать активным данный параметр, то в отчете 
можно будет использовать данные из системных таблиц; 

□ 8упопут$ — если сделать активным данный параметр, то из отчета мож¬ 
но будет обращаться к таблицам по их синонимам, если СУБД поддер¬ 
живает механизм создания синонимов; 

□ 81огей Ргосе<1иге$ — если сделать активным данный параметр, то в отчете 
можно будет использовать хранимые процедуры практически так же, как 
таблицы; 

□ ТаЫе паше ЫКЕ — поле, в которое можно вписать имя таблицы или часть 
имени, используя шаблон, либо перечислить через запятую несколько 
имен, которые будут использоваться в качестве условия формирования 
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списка допустимых таблиц. Шаблон имени может формироваться сле¬ 
дующим образом — если в поле вписать комбинацию символов СІІ$%, 
где знак процента — это любое количество неизвестных символов, то бу¬ 
дут выбираться таблицы с именами, начинающимися с СІІЗ и т. п.; 

□ Оѵѵпег ЫКЕ — если СУБД поддерживает такое понятие, как схема или 
владелец таблиц, то можно ограничить выбор таблиц, представлений и 
процедур. Для этого необходимо указать в поле имя владельца либо вос¬ 
пользоваться шаблоном, как в случае параметра ТаЫе пате ЫКЕ. В ре¬ 
зультате список доступных источников будет ограничен только теми, ко¬ 
торые принадлежат заданным владельцам. Имена владельцев желательно 
указывать в верхнем регистре. 

Подгруппа ІлвГ ТаЫея ап<1 ЕіеИ$ Ьу (Список таблиц и полей по) включает 

в себя такие элементы контроля, как: 

□ №те — при работе с данными показывать список имен таблиц и полей; 

□ Бевсгірйоп — при работе с данными показывать описание таблиц и полей; 

□ ВоЙі — при работе с данными показывать имена и описание таблиц 
и полей. 

Подгруппа 8огііп§ (Сортировка) позволяет выполнять сортировку имен таб¬ 
лиц и полей следующим образом: 

□ 8огГ ТаЫев АІрЬаЬеІісаІІу — сортировать имена таблиц в цифро-алфавит¬ 
ном порядке; 

□ 8огГ РіеІ(І$ АІрІіаЬеГісаІІу — сортировать имена полей в цифро-алфавитном 

порядке. ч 

Группа Агіѵапсегі Орііоп$ содержит набор параметров, которые предоставля¬ 
ют дополнительные возможности, используемые при работе с данными: 

□ Ше Ішіехез ог 8егѵег Гог 8реей — включает механизм использования ин¬ 
дексов или возможности сервера для оптимизации запросов; 

□ РегГогт Сгоиріп§ оп 8егѵег — включает механизм формирования запроса, 
выполняющего операцию группирования данных на сервере; 

□ ПаіаЬа$е 8егѵег і$ Са$е-Іп$еп$і(іѵе — данный параметр позволяет вклю¬ 
чить или отключить чувствительность к регистру символов, которые пе¬ 
редаются в запросе в качестве условия; 

□ 8еІесі Оівііпсі БаГа Гог Впго8іп§ — включает механизм выборки данных 
при просмотре без дублирования; 

□ РегГогт (^иегу АзупсЬгопоизІу — позволяет выполнять запросы к базе 
данных асинхронно; 

□ ѴегіГу Оп Ріг8І КеГгевЬ — включается механизм проверки структуры ис¬ 
пользуемых данных при выполнении обновления данных в момент вызо¬ 
ва отчета на просмотр; 
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□ Ѵегііу 8іогей Ргосейиге$ Оп Ріг§і КеГгезіі — включается механизм провер¬ 
ки структуры возвращаемого набора данных при выполнении обновления 
информации в момент вызова отчета на просмотр; 

□ Ѵегііу \ѴНеп ОаіаЬаке Бгіѵег 1)р§гайей — включается механизм проверки 
структуры используемых данных в случае изменения библиотеки, ис¬ 
пользуемой для связи с данными. 

Упражнение 7.3 

Попробуйте менять настройки, предназначенные для работы с базами дан¬ 
ных, и посмотрите результаты. 

7.4. Использование ЗОЬ-запросов 
при формировании отчетов 

В Сгу$1а1 К.ероП$ версии 9 внесены значительные изменения, связанные 
с использованием $0Ь-запросов. Как уже было сказано, в более ранних 
версиях Сгузіаі Керот существовала компонента Сгухіаі 8С>Ь Пе$і§пег, 
с помощью которой создавались сначала отдельные файлы 8()Ь-запросов, 
а затем эти файлы подключались к отчету как источник данных. Такой ме¬ 
ханизм, с одной стороны, позволял разработчику убедиться в правильности 
работы запроса перед тем, как использовать его в отчете, с другой стороны, 
имелся ряд значительных ограничений, которые требовалось принимать 
в расчет. Одним из таких ограничений является то, что Сгузіаі 8()Ь Оеы§пег 
для подключения к базам данных может использовать только СШВС- 
драйверы. Другое серьезное ограничение заключается в том, что непосред¬ 
ственно при работе с запросом в отчете нельзя его отредактировать для 
обеспечения требуемого результата. В Сгу$іа1 КероіТх версии 9 недочеты бо¬ 
лее ранних версий устранены, и разработчик обладает большим набором 
возможностей. Вместо механизма создания отдельного файла с 8фЬ- 
запросом предоставлена возможность формирования запроса непосредст¬ 
венно в момент выбора источника данных. Для этого, после того как источ¬ 
ник данных определен, вместо таблиц, представлений или хранимых проце¬ 
дур можно воспользоваться пунктом Айй Соттапй (Добавить команду) 
списка АѵаіІаЫе Баіа 8оигсе$ окна Баіа. Данный пункт показан на рис. 7.13. 
Первая выгода данного механизма заключается в том, что можно сформиро¬ 
вать запрос независимо от типа источника, который потом будет использо¬ 
ван для построения отчета. Вторая выгода заключается в том, что запрос 
доступен непосредственно в Сгузйі К.ероп$, а не через Сгу$1а1 8С>Ь Пе$і§пег, 
и его можно в любой момент исправить. Кроме того, любой запрос, сфор¬ 
мированный через раздел Айй Соттапй, можно сохранить в централизован¬ 
ном хранилище объектов, что дает возможность использовать один и тот же 
запрос для формирования различных отчетов и, в случае необходимости, 
использовать этот запрос как прототип для формирования других запросов. 
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Рис. 7.13. Окно Оаіа. Команда АсІсІ Соттапсі 



Г® Айв Соттапсі То КерогЬ 


ДЙЙ 301 чиеііі іп іЬе Ьо* ЬеІсЛ. 


г Раіатеім Ій 


Рис. 7.14. Диалоговое окно АсІсІ Соттапсі То КероіТ, позволяющее оформить 
новый запрос и задать его параметры 
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Для того чтобы создать 8()Ь-запрос, необходимо дважды щелкнуть левой 
клавишей мыши на строке Айй Соттапй, при этом появится диалоговое ок¬ 
но А<1<1 Сотташі То Керогі (Добавить команду в отчет), показанное 
на рис. 7.14. 

Данное окно содержит следующие элементы: 

□ окно Епіег 8<2Ь циегу іп іііе Ьох Ьеіоѵѵ — в это окно выписывается 8()Ь- 
запрос или копируется из любого текстового редактора; 

□ группа Рагашеіег Іл$і в составе: 

• окно, отображающее список параметров; 

• кнопка Сгеаіе — предоставляет возможность создать параметр для за¬ 
проса; 

• кнопка МойіГу — дает возможность отредактировать свойства пара¬ 
метра; 

• кнопка Кетоѵе — позволяет удалить параметр; 

□ опция А<1<1 іо Керо$ііогу (Добавить в хранилище) — дает возможность сра¬ 
зу же после формирования запроса записать его в хранилище как само¬ 
стоятельный объект, пригодный к многоразовому использованию. 

Запрос, пригодный к использованию, отображен на рис. 7.15. 


Е 


ДеЫ Соттапгі То Порог): 


Ьп)ег 5СИ срегу іп (Не Ьох ЬеЬл 


5ЕІ.ЕСТ -тОМОІЗТОМЕВ 


|7 Вероаіоо) 


г Раіатеіеі ІІ) Г ; ; V 1 : - —— 

У , . -- . 1 . •. : . ■ . . . 


“3 


3 


Сгеаіе... . 

МсоГу.. 1 


Яето-.'е 


ОК: 


~~] СапоеІ ■- ' 


\л 


Рис. 7.15. Диалоговое окно Асій СоттапсІ То ВероіТ с написанным запросом 


В случае, когда установлена опция Айй іо Керовііогу так, как показано 
на рис. 7.15, при нажатии на кнопку ОК сначала появляется окно Айй Ііеш 












176 


Гпава 7 


(Добавить элемент), в котором можно дать имя запросу как самостоятель¬ 
ному объекту, уточнить его синтаксис и указать, в какой раздел хранилища 
будет записан запрос. Окно А<і<1 Ііеш показано на рис. 7.16. 



Наше: 


|Клиекгы из тестовой базы 

АиІЬог: 

репіг 

Ое«сгір<іоп: 

5ЕІ.ЕСТ 'РВОМ СІІ5Т0МЕВ Т] 

А 

Іосаііоп: 

В • Ѳ СгузЬэІ Р.еро5І(:огу 
30 Ш Ітадез 
В-'СЗ ТехЬ 0Ь]'ес(з 
3- <ЕЗ СотталсІ5 

: • "Ц СизЕотегОггіегзБЬірресі 
: [Ц Етріоуевіп^о 
■ • Щ] Выборка заказов 


0к | СапсеГ 


Рис, 7.16. Окно Мб Нет 

После того как процесс записи запроса в хранилище завершен, запрос авто¬ 
матически попадает в раздел Зеіесіей ТаЫе8 (Выбранные таблицы) окна 
Баіа так, как это показано на рис. 7.17. 

Все последующие действия по формированию отчета совпадают с механиз¬ 
мами, описанными в предыдущих главах данной книги. 

Как уже было определено ранее, любой 5()Ь-запрос может содержать один или 
несколько параметров, которые будут обрабатываться на уровне отчета так же, 
как и поля-параметры. Для того чтобы создать параметр, который затем может 
быть использован в запросе, необходимо нажать на кнопку Сгеаіе (Создать), 
при этом откроется окно Сотташі Рагатеіег (Параметр 5фЬ-команды), пока¬ 
занное на рис. 7.18, позволяющее определить свойства параметра. 

Механизмы работы с параметрами совпадают с механизмами, которые опи¬ 
саны в разд. 2.5. Однако существует ряд отличий, о которых необходимо 
помнить. Параметр, используемый в ЭДЬ-запросе, не может быть оформлен 
как диапазон или массив. Параметр в запросе всегда определяется как дис¬ 
кретное значение. 
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Рис. 7.17. Окно Раіа с выбранным запросом в качестве источника данных 



Рис. 7.18. Окно Соттапс] Рагатеіег, позволяющее определить 
свойства параметра, используемого в ЗОЬзапросе 













Рис. 7.20. Окно МосііГу Соттапсі с запросом, содержащим параметр 


Для того чтобы добавить параметр в 5()Ь-запрос, необходимо установить 
курсор в окне Епіег чиегу іп Йіе Ьох Ьеіоѵ (Впишите 5()Ь-запрос в по¬ 
ле) в то место, куда требуется поместить параметр, и затем, дважды щелкнув 
левой клавишей мыши по параметру в списке, переместить его в текст 
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запроса. При использовании такого механизма добавления параметров в за¬ 
прос автоматически учитывается необходимый синтаксис. Результат вклю¬ 
чения параметра в запрос показан на рис. 7.20. 

В случае, когда отчет формируется на основании запроса, содержащего па¬ 
раметр, в момент выбора запроса появляется окно, предлагающее задать 
значение параметра или нескольких параметров. Окно определения значе¬ 
ния для параметра показано на рис. 7.21. Точно такое же окно будет ото¬ 
бражаться в отчете в случае обновления данных. 


Епіег Рагатеіег Ѵаіиев 


Рагатеіег ріёіеб: 


Город 



Укажите наименование города 



ОК | СапсеІ Неір 


Рис. 7.21. Окно Епіег Рагатеіег Ѵаіиез 


В случае, когда возникает потребность в запросе, записанном в хранилище, 
необходимо использовать раздел Керозііогу в окне Оаіа. В хранилище выби¬ 
рается нужный запрос из соответствующего раздела и двойным щелчком 
левой клавишей мыши или нажатием на кнопку со стрелочкой, направлен¬ 
ной вправо, производится подключение запроса как источника данных для 
отчета. Окно Ваіа с разделом Керозііогу показано на рис. 7.22. 

Если запрос настроен на работу с источником данных, запрашивающим имя 
пользователя и пароль, в момент подключения появляется окно, предла¬ 
гающее указать требуемую информацию. 
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Рис. 7.22. Окно Оаіа. Выбор ЗОЬ-запроса из хранилища 


Если запрос, который содержится в хранилище, используется только в каче¬ 
стве шаблона, требующего изменений, необходимо выполнить следующие 

действия: 

1. Из хранилища выбирается запрос, который может быть использован 
в качестве шаблона, и подключается как источник данных. 

2. Для выбранного запроса правой клавишей мыши вызывается контекст¬ 
ное меню, показанное на рис. 7.23. 

3. В контекстном меню выбирается команда Бі8СОппесІ Ггот Керо$ііогу 
(Отключиться от хранилища) для того, чтобы освободить запрос. 

4. После отключения от хранилища повторно вызывается то же самое кон¬ 
текстное меню, только теперь в нем доступна команда Е<Ш Сотіпаші 
(Редактировать команду). 

5. После выполнения команды меню Егііі Сошшапгі появляется окно МсиІіГу 
Сопіпіаші (Модификация команды), показанное на рис. 7.19 и 7.20. 
В этом окне можно выполнять все действия по изменению запроса. 
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6. Вновь полученный вариант запроса, так же как и новый запрос, можно 
использовать в пределах одного отчета, а можно записать в хранилище 
как самостоятельный объект. 


• Ёсііі СутпРГйгхі 

Ѵіеѵч Соттапсі 

ОівсоппесЬ ?гот Кермйогу 
СапсеІ Мепи 

Рис. 7.23. Контекстное меню, позволяющее 
отключить запрос от хранилища 


|Г Примечание ^ 

Одновременное использование 301-запроса, таблиц, представлений и храни¬ 
мых процедур недопустимо. 


7.5. Введение в язык ЗСН. 

Для правильного построения ЗСІЬ-запросов необходимо знать операторы 
и синтаксис языка ЗС^Ь. Учитывая то, что материал этой книги посвящен 
использованию Сгумаі Керогй, рассмотрение языка ЗрЬ будет ограничено его 
аспектами, имеющими приложение непосредственно к генератору отчетов. 

Если рассматривать язык ЗС^Ь в полном объеме, можно разбить его опера¬ 
торы на три основных категории: 

1. Язык определения данных или Баіа ОеГіпйіоп Еаіщиа§е — создание объ¬ 
ектов базы данных. 

2. Язык манипулирования данными или Баіа Мапіриіайоп Ьап§иа§е — оп¬ 
ределяет, какие данные представлены в таблицах. 

3. Язык управления данными или Баіа Сопігоі Ьап§иа§е — определяет, мо¬ 
жет ли пользователь выполнить действие. 

При работе Сгузіаі Рероіія 9 используется только язык манипулирования 
данными или категория Эаіа Мапіриіаііоп Ьап§иа§е. К данному разделу от¬ 
носятся операторы: 

□ ІИЗЕКТ — вставка данных; 

□ ЕІРОАТЕ — модификация данных; 

□ БЕЬЕТЕ — удаление данных; 

□ ЗЕЬЕСТ — выборка данных. 

Учитывая то, что Сгу$ШІ Керогй 9 не изменяет данные в источниках, опе¬ 
раторы ІШЕКТ, УРБАТЕ и ОЕЬЕТЕ рассматриваться не будут. Будет 
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рассмотрен синтаксис запросов, обеспечивающих выборку данных и их 
комбинацию. В качестве источника данных можно пользоваться любой ба¬ 
зой, которая есть у вас под рукой. Если нет ни одного источника данных, 
можно взять базу данных Місго$оЙ Ассезз (хггете.тдЪ), которая устанавли¬ 
вается совместно с Сгузіаі Керогів 9 и находится в каталоге примеров. Ис¬ 
пользование этой базы данных описано в первых главах данной книги. 

Все 8()І_-запросы состоят из предложений или сіаизез. В качестве примера 
предложений можно представить следующие конструкции: 

□ РВОМ Сшіотег 

□ \ѵневе си8ТомЕв.си8ТомЕвт=отси5ТомЕкт 

Базовая конструкция ЗОЬ-запроса для выборки данных из одной таблицы 
представлена на схеме 7.1. 


$ЕІ_ЁСТ 


-АН— 

— ОІЗТІМСТ- 

РВОМ - 


ЗНАЧОК' ИЛИ список 
КОЛОНОК ЧЕРЕЗ ЗАПЯТУЮ 


ИМЯ ТАБЛИЦЫ В БАЗЕ ДАННЫХ 


Схема 7.1. Базовая конструкция запроса типа Зеіесі 


□ Предложение АЬЬ указывает на необходимость выборки всех данных из 
таблицы. Это предложение не является обязательным. 

□ Предложение ОІ8ТІІѴСТ позволяет выбирать данные из таблицы без по¬ 
втора дублирующихся строк. 

□ Значок звездочка указывает на то, что необходимо выводить данные из 
всех полей таблицы. 


Упражнение 7.4 

1. Напишите запросы, выбирающие данные из разных таблиц, и сформи¬ 
руйте на их основании отчеты. 

2. Сравните результаты, которые получаются при использовании предложе¬ 
ний АЬЬ и ОІ8ТШСТ. 

В процессе работы с запросами может оказаться, что набор данных, которые 
возвращаются выражением, слишком велик. Для того чтобы сократить ко¬ 
личество строк, можно в запросе установить фильтр. Способ установки 
фильтра показан на схеме 7.2. 

При задании параметров фильтрации можно использовать различные реля¬ 
ционные операторы: 

□ = — равенство; 
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□ > — больше; 

□ < — меньше; 

□ >= — больше или равно; 

□ <= — меньше или равно; 

□ О, != — не равно и др. 


5ЕІЁСТ 


РВОМ - 


— АН- 

ЦІЗТІЙСТ- 

ИМЯ ТАБЛИЦЫ 
В БАЗЕ ДАННЫХ 


ЗНАЧОК * ИЛИ СПИСОК 
КОЛОНОК ЧЕРЕЗ ЗАПЯТУЮ 


УСЛОВИЕ 

ѴѴНЕЙЕ -ФИЛЬТРАЦИИ 

ДАННЫХ 


Схема 7.2. Конструкция запроса 8ЕІ_ЕСТ с установленным фильтром 


^ Примечание 

Оператор "не равно” в различных СУБД может быть определен с помощью 
различных символов. 

Запрос с установленным фильтром может выглядеть так: 

ЗЕЬЕСТ ЦАМЕ, СІТУ, ЗЦММ РКОМ СЫЗТОМЕК МНЕКЕ СОШТКУ=' Киззіа' 

Кроме реляционных операторов существует набор булевых операторов, ко¬ 
торые могут быть использованы совместно с реляционными: 

□ АЫБ — логическое и; 

□ ОК — логическое или; 

□ ИОТ — логическое отрицание. 

Примеры совместного использования реляционных и булевых операторов: 

ЗЕЬЕСТ ЦАМЕ, СІТУ, ЗЦММ РКОМ СЫЗТОМЕК МНЕКЕ СОШТКУ= ’ Киззіа ' АЖ) ЗШМ>1000 
ЗЕЬЕСТ ИАМЕ, СІТУ, 5ШМ РКОМ СОЗТОМЕК МНЕКЕ СОШТКУ=' Киззіа ' ОК ЗЖМ>1000 
ЗЕЬЕСТ РШЕ, СІТУ, ЗОШ РКСМ СЛЗТСМЕК МНЕКЕ СОШТКУ=' Киззіа' АШ ГОГ ЗЦММ>1000 

Используя круглые скобки, можно комбинировать различные булевы опера¬ 
торы и создавать сложные формулы фильтрации данных. 

Например: 

ЗЕЬЕСТ Г®МЕ, СІТУ, ЗЦММ ЕКСМ СЦЗТШЕК МНЕКЕ ГОГ (ССШТКУ= 'Киззіа' ОК ЗШМ>1000) 

Упражнение 7.5 

Напишите запросы с фильтрацией данных, используя все возможные опера¬ 
торы, и посмотрите результаты в виде отчетов. 

В ряде случаев может оказаться, что реляционных и булевых операторов не¬ 
достаточно для реализации запроса, возвращающего удовлетворительный 
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результат. Для решения специфических проблем существует набор специ¬ 
альных операторов, которые облегчают разработку корректных запросов. 

Очень часто возникает необходимость установить фильтрацию не по одному 
значению, а по целому списку. Реализовать такое ограничение можно с по¬ 
мощью оператора ОК. Это будет выглядеть так: 

ЗЕЬЕСТ ЫАМЕ, СІТУ, ЗШМ РКОМ СЦЗТОМЕК ИНЕКЕ СОШГТКУ=' Киззіа ' ОК 
СОШТКУ='Ц8А' ОК СОШТКУ=' Сегтапу' ... 

Такое перечисление не всегда удобно использовать, и, кроме того, средства 
разработки приложений и генераторы отчетов могут иметь ограничение на 
длину строки. Для того чтобы сделать строку $рі_-запроса короче, можно 
воспользоваться оператором І1Ч. В этом случае строка запроса будет выгля¬ 
деть так: 

ЗЕЬЕСТ ЫАМЕ, СІТУ, ЗШМ РКОМ СЦЗТОМЕК ИНЕКЕ СОШТКУ ІЫ ('Киззіа', 'ЦЗА' , 
'Сегтапу', ...) 

За счет такого определения списка значений можно сократить длину запро¬ 
са практически вдвое. 

При необходимости задать диапазон значений также существует два вариан¬ 
та реализации запроса. Первый вариант — это использование реляционных 
операторов >= и <=: 

ЗЕЬЕСТ ЫАМЕ, СІТУ, 5ШМ РКОМ СЦЗТОМЕК МНЕКЕ 5ШМ>=1000 АЖ> ЗЦШ<=5000 
Второй вариант предполагает использование оператора ветнееы ... ажз ...: 

ЗЕЬЕСТ ЫАМЕ, СІТУ, 8ШМ РКОМ СЦЗТОМЕК ИНЕКЕ 50ММ ВЕТНЕЕЫ 1000 АЖ> 5000 

Так же как и в первом варианте, этот оператор включает границы диапазо¬ 
на. Если необходимо исключить границы диапазона, можно реализовать это 
так: 

ЗЕЬЕСТ ЫАМЕ, СІТУ, ЗЦММ РКОМ СЦЗТОМЕК ИНЕКЕ 5ЦЖ>1000 АЖ) 5ШПУК5000 

либо: 

ЗЕЬЕСТ ЫАМЕ, СІТУ, ЗЦММ РКОМ СЦЗТОМЕК ИНЕКЕ 50ММ ВЕТНЕЕЫ 1000 АЖЗ 5000 
АЖЗ ЗЦММ дат ІЫ (1000,5000) 

Очень часто бывает так, что поля базы данных содержат специальное значе¬ 
ние ІЧІЛД,. М1Л_Ь — это не пробел и не ноль, это отсутствие какого-либо 
значения. Для его обработки можно использовать специализированные опе¬ 
раторы 13 N1311 и 13 ЫОТ ИШЬ. Запросы, которые определяют наличие 
в поле значения ЫШХ либо значения любого другого имеющегося в базе 
данных типа, выглядят так: 

ЗЕЬЕСТ ЫАМЕ, СІТУ, ЗЦММ РКОМ СЦЗТОМЕК ИНЕКЕ РНОЫЕ 18 ЫЦЬЬ; 

ЗЕЬЕСТ ЫАМЕ, СІТУ, ЗЦММ РКОМ СЦЗТОМЕК ИНЕКЕ РНОЫЕ 18 ЫОТ ЫЦЬЬ 

В случае необходимости можно организовать фильтр, который выполняет 
отбор данных не по целому значению, а по подстроке. К сожалению, этот 
оператор ориентирован на работу только с текстовыми значениями. Для ра- 
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боты с подстрокой используется оператор 1ЛКЕ. Конструкция подстроки, 
подставляемой в качестве условия, использует следующие специальные сим¬ 
волы %, * и ?. Если требуется указать, что строка должна начинаться с сим¬ 
вола или набора символов, то условие выглядит так: 

ЗЕЬЕСТ ЦАМЕ, СІТУ, 8ШМ ЕКОМ СЦЗТОМЕК МНЕКЕ СІТУ ЫКЕ >К%' 

здесь отбираются города с названиями, начинающимися на букву К. 

Если необходимо выполнить поиск строки, которая завершается заданным 
набором символов, то условие выглядит так: 

ЗЕЬЕСТ ЦАМЕ, СІТУ, 8ШМ ЕКОМ СЦЗТОМЕК МНЕКЕ СІТУ ЫКЕ *%К' 

В случае, когда требуется искать строки, которые содержат комбинацию 
символов в любом месте, запрос можно построить так: 

ЗЕЬЕСТ ЦАМЕ, СІТУ, 5ШМ ЕКОМ СЦЗТОМЕК МНЕКЕ СІТУ ЫКЕ '%К%' 

В этом запросе отбираются значения, содержащие букву К в любом месте. 

В. ряде случаев может возникнуть потребность осуществлять поиск по под¬ 
строке, в которой не все символы известны, тогда для указания неизвестных 
символов можно использовать оператор подчеркивание. Количество значков 
подчеркивания соответствует количеству неизвестных символов. Запрос 
в этой ситуации выглядит так: 

ЗЕЬЕСТ ЦАМЕ, СІТУ, ЗШМ РКОМ СЦЗТОМЕК МНЕКЕ СІТУ ЫКЕ '%К_2%' 

В этом запросе отбираются значения, содержащие в любом месте фрагмент 
из трех букв, начинающийся на К и кончающийся на 2 с произвольным 
символом на втором месте. 


Упражнение 7.6 

1. Используя предложенный вариант базы данных, напишите запрос, выби¬ 
рающий всех клиентов, имена которых начинаются с буквы К, и по¬ 
стройте отчет. 

2. Напишите запрос, выбирающий всех клиентов, в именах которых встре¬ 
чается буква К, и постройте отчет. 

3. Напишите запрос, выбирающий всех клиентов, имена которых начина¬ 
ются с любой буквы от А до К, и постройте отчет. 

4. Напишите запрос, выбирающий всех клиентов, у которых не введены 
сведения о городе, и постройте отчет. 

В большинстве случаев запросы необходимы не только для того, чтобы вы¬ 
брать и отфильтровать данные, но и для того, чтобы выполнить какие-либо 
действия над данными либо их преобразование в тот вид, который будет 
удобен для работы. Для работы с данными с помощью 5(^Ь-запросов суще¬ 
ствует набор функций, который в зависимости от выбранной СУБД может 
меняться, но большинство из них идентичны и их синтаксис один и тот же. 
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К таким функциям относятся агрегатные или статистические функции. 
Вот список наиболее часто встречающихся статистических функций: 

□ АѴО — вычисление среднего значения по полю; 

□ 81ЛѴІ — вычисление суммы по полю; 

□ СОІЖТ — вычисление количества записей; 

□ МШ или МАХ — вычисление минимального или максимального значе¬ 
ния поля. 

Кроме этих функций существует еще очень большое количество других, но 
как уже было сказано, для каждой СУБД этот набор различен, и информа¬ 
цию о нйх необходимо уточнять в документации, сопровождающей кон¬ 
кретный тип и версию СУБД. Так же некоторые СУБД имеют механизмы, 
которые, позволяют пользователю создавать свои функции, отличные от ба¬ 
зовых. Использование таких функций в ЗОЬ-запросах может существенно 
упростить работу по построению отчетов на основе запросов. 

Запросы, которые используют описанные функции, могут выглядеть так: < 

ЗЕЬЕСТ АѴСЦЗШМ) РКОМ СЦЗТОМЕК ИНЕКЕ СІТУ= 'Мозсоад' л 

ЗЕЬЕСТ ЗШ(ЗЦММ) РКОМ СЦЗТОМЕК ИНЕКЕ СІТУ= 'Мозсои' 

\ 

ЗЕЬЕСТ МШ(ЗЦММ) РКОМ СЦЗТОМЕК ИНЕКЕ СІТУ= 'Мозсозд' 

ЗЕЬЕСТ МАХ(ЗЦММ) РКОМ СЦЗТОМЕК ИНЕКЕ СІТУ= ’Мозсозд' 

Запрос, который будет использовать функцию СОІЛЧТ, может иметь раз¬ 
личные варианты оформления: 

□ зеьест сошт (*) рком отзтомЕК— вычисление количества записей в таб¬ 
лице; 

□ зеьест сошт(сіту) рком сцзтомЕК— вычисление количества записей 
в таблице, без учета тех, где поле СІТУ имеет значение ІЧІЛХ; 

□ зеьест сошт (шзтшст сіту) рком сцзтомек — вычисление количества 
записей в таблице, считая две записи с одним значением поля СІТУ за 
одну и без учета тех, где поле СІТУ имеет значение ЫІЛХ. 

Примечание 

При попытке выполнить запрос, имеющий функцию С0ІЛМТ(0І8ТІМСТ СІТУ), 
в МісгозоЙ Ассезз будет выдано сообщение об ошибке. 

Необходимо учитывать то, что статистические функции возвращают единст¬ 
венное значение и использование их совместно с реальными колонками 
приведет к ошибке, если не использовать предложение ОКСШР ВУ. 

Текст сообщения об ошибке может меняться, но ее смысл не меняется. Ба¬ 
зовый синтаксис использования предложения СЖСШР ВУ показан на схе¬ 
ме 7.3. Предложение ОКОТІР ВУ объединяет записи с одинаковыми значе¬ 
ниями в указанном списке полей в одну запись. 
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ЗЕІ.ЕСТ 


— АН— 

0І5ТІМСТ* 


ЗНАЧОК * ИЛИ СПИСОК 
КОЛОНОК ЧЕРЕЗ ЗАПЯТУЮ 


РВОМ - ИМЯ ТАБЛИЦЫ В БАЗЕ ДАННЫХ 


СПИСОК КОЛОНОК, 

КОТОРЫЕ ПРИСУТСТВУЮТ 
В ЗАПРОСЕ, НО НЕ ИСПОЛЬЗУЮТСЯ 
В АГРЕГАТНЫХ ФУНКЦИЯХ 


Схема 7-3. Базовая конструкция запроса, использующего предложение СВОІІР ВУ 


Сам запрос в этом случае будет выглядеть так: 

ЗЕЬЕСТ ЫАМЕ, СОШТ(СІТУ) РКОМ ОТ5ТОМЕК СКООТ ВУ ЫАМЕ 

Если требуется наложить ограничение на выбираемый набор значений, то 
можно воспользоваться предложением ѴѴНЕКЕ. Это предложение должно 
стоять перед предложением ОКОІІР ВУ (схема 7.4). 


ЗЕЦЕСТ 


— ап— 

РІЗТІЫСТ- 


ЗНАЧОК» или список 
КОЛОНОК ЧЕРЕЗ ЗАПЯТУЮ 


РВОМ 


ИМЯ ТАБЛИЦЫ 
В БАЗЕ ДАННЫХ 


УСЛОВИЕ 

ѴѴНЕКЕ - ФИЛЬТРАЦИИ 

ДАННЫХ 


скоир вѵ 


список колонок, 

КОТОРЫЕ ПРИСУТСТВУЮТ 
В ЗАПРОСЕ, НО НЕ ИСПОЛЬЗУЮТСЯ 
В АГРЕГАТНЫХ ФУНКЦИЯХ 


Схема 7.4. Структура запроса, использующего СВОІІР ВУ и ѴѴНЕВЕ 


ЗЕІЕСТ 


— АН— 
0І5ТШСТ- 


ЗНАЧОК * ИЛИ список 
КОЛОНОК ЧЕРЕЗ ЗАПЯТУЮ 


РКОМ 


ИМЯ ТАБЛИЦЫ 
В БАЗЕ ДАННЫХ 


УСЛОВИЕ 

ѴѴНЕКЕ -ФИЛЬТРАЦИИ 

ДАННЫХ 


екоцр вѵ 


наѵіцс 


список колонок, 

КОТОРЫЕ ПРИСУТСТВУЮТ 
В ЗАПРОСЕ, НО НЕ ИСПОЛЬЗУЮТСЯ 
В АГРЕГАТНЫХ ФУНКЦИЯХ 

УСЛОВИЕ ОГРАНИЧЕНИЯ, КОТОРОЕ 
УСТАНАВЛИВАЕТСЯ НА ЗНАЧЕНИЕ, 
ЯВЛЯЮЩЕЕСЯ РЕЗУЛЬТАТОМ ОТ ОБРАБОТКИ 
АГРЕГАТНОЙ ФУНКЦИИ 


Схема 7.5. Структура запроса, использующего предложение НАѴІІЧС 
совместно с СВОІІР ВУ 


Пример запроса: 

ЗЕЬЕСТ ИАМЕ, СОтТ(СІТУ) РКОМ ОТ5ТОМЕК ИНЕКЕ 8ШМ>1000 СКОИР ВУ ЫАМЕ 

Если потребуется наложить дополнительные ограничения на выбранные и 
сгруппированные данные, можно воспользоваться предложением НАѴШО, 


7 Зак. 1021 
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которое позволяет установить фильтр на значения, возвращаемые агрегат¬ 
ной функцией (схема 7.5). Предложением ѴѴНЕК.Е в этом случае пользо¬ 
ваться нельзя. 

В таком исполнении запрос будет выглядеть так; 

ЗЕЬЕСТ ЫАМЕ, ССШТ(СІТУ) РКОМ ОТ5ТОМЕК МНЕКЕ 5ШМ>1000 СКОЬГР ВУ ЫАМЕ 
НАѴШС СОШТ(СІТУ)>1 


Упражнение 7.7 

1. Используя имеющуюся у вас структуру данных, напишите запрос, под¬ 
считывающий количество городов в таблице клиентов, и создайте на его 
основании отчет. 

2. Напишите запрос, выбирающий товар с наименьшей ценой, и создайте 
на его основании отчет. 

Результаты, которые возвращаются запросом, не всегда удовлетворяют тре¬ 
бованиям форматирования. Для того чтобы результат выглядел красивее, 
можно в текст запроса включать данные, которые не относятся непосредст¬ 
венно к источнику. При этом запрос может иметь следующий вид: 

ЗЕЬЕСТ 'Наименование',ЫАМЕ, 'Количество', СОШТ(СІТУ) ЕКОМ ОТ5ТОМЕК ИНЕКЕ 
5ШМ>1000 СКОЦР ВУ ЫАМЕ НАѴІЫС СОШТ(СІТУ)>1 

При выполнении такого запроса результирующий набор данных будет со¬ 
держать в первой и третьей колонках константы — "Наименование" и 
"Количество", а во второй и четвертой колонках два поля из базы данных — 
ЫАМЕ и СОІЖТ(СІТУ) соответственно. При желании можно объединить 
все поля в одно, для этого используются операторы конкатенации или 
слияния строк. Для различных СУБД эти операторы могут иметь различный 
вид. Наиболее часто встречающиеся варианты — это || (две вертикальных 
черты) или + (плюс). В случае слияния данных из нескольких полей необ¬ 
ходимо учитывать, что типы данных должны быть строковыми. Если необ¬ 
ходимо объединить данные из строкового поля и цифрового, то требуется 
преобразовать цифровое значение в строку, хотя некоторые СУБД и не тре¬ 
буют явного преобразования. Предыдущий запрос, использующий слияние 
данных, можно описать так; 

ЗЕЬЕСТ 'Наименование 'I|ЫАМЕ||' Количество '||ТО_СНАК(СОШТ (СІТУ) ) ЕКОМ 
ОТЗТОМЕК ИНЕКЕ ЗЦММ>1000 СКОЦР ВУ ЫАМЕ НАѴІЫС СОЦЫТ (СІТУ) >1 

Результатом выполнения такого запроса будет всего лишь одна колонка, со¬ 
держащая объединение данных из нескольких полей базы данных и допол¬ 
нительных элементов форматирования. 

Однако при использовании слияния данных либо функций заголовок ре¬ 
зультирующего набора данных будет выглядеть некрасиво, причем для раз¬ 
личных типов источников эти заголовки будут различаться. 
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Для того чтобы результат был более красивым и понятным, можно опреде¬ 
лить псевдоним для тех колонок или сборных данных, которые отображают¬ 
ся некорректно. Псевдоним колонки задается с помощью предложения АЗ. 
При этом сам запрос будет выглядеть так: 

ЗЕЬЕСТ 'Наименование '||ЫАМЕ||' Количество ' I |ТО_СНАК(СОШТ(СІТУ) ) АЗ 
Информация ЕКОМ СЦЗТОМЕК ИНЕКЕ 8ЦММ>1000 СКОЦР ВУ ЫАМЕ НАѴІЫС СОЦОТ (СІТУ) >1 

Псевдонимы у колонок могут быть использованы также в случае необходи¬ 
мости представления пользователю данных более понятным образом. 

Учитывая то, что данные в реляционных базах хранятся в произвольном по¬ 
рядке, возникает необходимость их сортировки. Для сортировки использует¬ 
ся предложение (ЖРЕЯ ВѴ. Если необходимо сортировать данные в поряд¬ 
ке возрастания, используется ключ АЗС либо ничего не указывается, т. е. 
сортировка по возрастанию применяется по умолчанию. В случае, когда 
требуется сортировка по убыванию, употребляется ключ РЕЗС. Используя 
комбинацию предложения ОКРЕП ВУ и ключей А5С/РЕ5С, можно орга¬ 
низовать сортировку данных по разным полям, причем по каждому полю 
может быть установлен свой порядок. Возможное представление запроса 
может выглядеть так: 


ЗЕЬЕСТ ЫАМЕ, СІТУ, 
ЗЕЬЕСТ МАМЕ, СІТУ, 
ЗЕЬЕСТ ЫАМЕ, СІТУ, 
ЗЕЬЕСТ ИАМЕ, СІТУ, 
ЗЕЬЕСТ ИАМЕ, СІТУ, 


5ШМ ЕКОМ СЦЗТОМЕК ОИЭЕК ВУ ИАМЕ 

8ШМ ЕКОМ СЦЗТОМЕК ОКПЕК ВУ ЫАМЕ АЗС 

ЗЦММ ЕКОМ СЦЗТОМЕК ОИЭЕК ВУ ЫАМЕ ЦЕЗС 

зимм ЕКОМ СЦЗТОМЕК ОИЭЕК ВУ ЫАМЕ, СІТУ 

ЗЦММ ЕКОМ СЦЗТОМЕК ОИЭЕК ВУ ЫАМЕ АЗС, СІТУ ЦЕЗС 


^ Примечание 

При использовании предложения ОПОЕН ВУ необходимо учитывать то, что 
некоторые СУБД позволяют совмещение этого предложения с ѲКОІІР ВУ, 
а некоторые нет. 


Упражнение 7.8 

1. Используя имеющуюся структуру базы и набор данных, напишите за¬ 
прос, выдающий список товаров в порядке убывания стоимости и соз¬ 
дайте на его основании отчет. 

2. Напишите запрос, который имеет несколько условий сортировки, и создайте 
на его основании отчет. Измените порядок сортировки, посмотрите результат. 

Часто возникает необходимость объединять данные из двух и более таблиц 
так же, как при построении отчета с помощью редактора ОаіаЬазе Ехрегі. 
Такой механизм в языке ЗС^Ь называется ЮШ (соединение). Для объедине¬ 
ния данных из двух и более таблиц в запросе необходимо описать условие 
соединения в предложении ѴѴНЕЯЕ. Базовый способ предполагает равенство 
ключевых полей в связываемых таблицах. При этом необходимо учитывать 
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то, что при описании связи необходимо указывать полное имя поля. Полное 
имя поля, как минимум, состоит из имени таблицы и имени поля: 

<Имя таблицы>.<Имя поля>. 

Синтаксически конструкция запроса с ЮШ формируется так, как это пока¬ 
зано на схеме 7.6. 

ЗНАЧОК* или список 
КОЛОНОК ЧЕРЕЗ ЗАПЯТУЮ 


ИМЕНА ТАБЛИЦ БАЗЫ ДАННЫХ, 
РАЗДЕЛЕННЫЕ ЗАПЯТОЙ 


ИМЯ ТАБЛИЦЫ 1. ИМЯ КОЛОНКИ 1 

»- ѴѴНЕЯЕ -УСЛОВИЕ СВЯЗЫВАНИЯ - АЦО|ОЙ 

ИМЯ ТАБЛИЦЫ'2. ИМЯ КОЛОНКИ 2 

Схема 7.6. Структура запроса с условием соединения таблиц .ЮІИ 


ЗЕЦЕСТ- 


-АІД- 


■ оіатімст— 


Как видно из схемы, в случае, когда таблицы имеют более одного ключевого 
поля, условия сравнения объединяются через логическое и — АК'О. То же 
самое будет происходить при связывании данных из трех и более таблиц. 
Пример запроса выглядит так: 

ЗЕЛЕСТ СЦЗТОМЕК.ЦАМЕ, СЦЗТОМЕК. СІТУ, СЦЗТОМЕК.5ШМ, ОКО. ОКЛЕКІЛ , 
ОКЛ.ЛАТЕО, ОКЛ.ЛАТЕК, ОКЛ. БШМ РКОМ СЦ5Т0МЕК, ОКЛ ШЕКЕ 
СЦЗТОМЕК. СЦЗТОМЕКІЛ = ОКЛ. СЦЗТОМЕКІЛ; 

ЗЕЛЕСТ СЦЗТОМЕК.МАМЕ, СЦЗТОМЕК. СІТУ, СЦЗТОМЕК.5ШМ, 5АЛЕ5РЕ0РЛЕ.ЫАМЕ, 
8АЛЕ5РЕ0РЛЕ.СІТУ, 5АЛЕ5РЕ0РЛЕ. СОШІТКУ, ЗАЛЕ5РЕ0РЛЕ.СОММ, ОКЛ. ОКЛЕКІЛ, 
ОЕЛ.ЛАТЕО, ОКЛ.ЛАТЕК, ОКЛ.5ШМ РКОМ СЦ5Т0МЕК, ЗАЛЕЗ РЕОРЛЕ , ОКЛ ШЕКЕ 
СЦЗТОМЕК. СЦЗТОМЕКІЛ = ОКЛ. СЦЗТОМЕКІЛ АЖ) ЗАЛЕЗ РЕОРЛЕ . 5АЛЕ5РЕОРЛЕІЛ = 

ОКЛ. ЗАЛЕЗ РЕОРЛЕІЛ 

Если требуется изменить условия связывания данных, то можно воспользо¬ 
ваться любыми другими реляционными операторами вместо равенства. 

В ряде случаев может возникнуть ситуация, представленная на рис. 7.24-7.26. 


ЗОІМРАКЁМТ _ 

Р_Ю: ШИВЕР 

ЫАМЕ: ѴАПСНАЯ2(20) 
СОММЕЫТАРѴ ѴАКСНАП2Р54) 

-- 

-ЮІІМСНІШ _ 

СН_10; ЫЦМ8ЕП 

Р 10: ШМВЕП (РК) 

СНІШЫАМЕ: ѴАКСНАР2(20) 
СОММЕМАКУ. ѴАКСНАК2(254) 


Рис. 7.24. Две связанные таблицы 
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Рис. 7.25. Данные в родительской таблице 
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12,00 

ШшіРіІ 

ОША N0 СОММЕЫТ 


13,00 
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ЕСОН МО СОММЕЫТ 


15,00 

3,00 

1НА ЫО СОММЕЫТ 


16.00 


5І.АѴА ЫО СОММЕЫТ 



МІНАІІ. ЫО СОММЕЫТ 


1 8,00 : 

ЗТЕРАЫ ЫО СОММЕЫТ 


Рис. 7.26. Данные в дочерней таблице 


Если обратиться к этим таблицам с запросом: 

ЗЕЬЕСТ ДОШРАКЕЫТ.ЫАМЕ, ДОШРАКЕГГГ.СОММШТАКУ, ДОІЫСНІЬО.СНІЬЕЫАМЕ, 
ЛОШСНІЬБ.СОММЕЫТАКУ РКОМ ДОІЫРАКЕЫТ, ДОШСНІЫЭ ЩЕКЕ ЛОІЫРАКЕМТ. Р_Ю = 
ДОШСНІІЛЭ.Р_:ГО , 

то результат будет выглядеть так, как это представлено на рис. 7.27. 






ІѴАЫ 

ЫО СОММЕЫТ ' ѴАМѴА ЫО СОММЕЫТ 

ЫО СОММЕЫТ 6 ИЗ А ! МОСОММЕЫТ 


ЗѴЕТиЫА 

ЫО СОММЕЫТ АЬЕХ ЫО СОММЕЫТ 


ѴАЗІШ 

Ы0 СОММЕЫТ ЕСОВ ІЫО СОММЕЫТ 


ѴАЗІШ 

ЫО СОММЕЫТ |іВА ІЫО СОММЕЫТ 


МАМА 

N0 СОММЕЫТ ЗіАѴА N0 СОММЕЫТ 


Рис. 7.27. Выборка данных с условием связывания Ециа! Эоіп 


Как видно из рис. 7.27, записи результирующего набора данных составляют¬ 
ся только из тех записей связанных таблиц, которые имеет полное соответ¬ 
ствие значений в ключевых колонках, т. е. отбираются только те записи ро¬ 
дительской таблицы, которым соответствует хотя бы одна запись дочерней и 
наоборот. Это не всегда удобно. Иногда надо получить такой набор данных, 
который содержит не только связанные значения, но и информацию из 
записей, не связанных с другими. Для этого используются механизмы ЬеГі и 
Кі§1и Оиіег .Іоіп. При работе с Огасіе такая обработка выполняется с помощью 
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значка +. Выражение с условием связывания ЬеЛ Оиіег іоіп для СУБД 
Огасіе будет выглядеть так: 

ЗЕЬЕСТ ДОШРАКЕЫТ.ЫАМЕ, ДОІЫРАКЕЫТ.СОММЕЫТАКУ, ДОІЫСНІІЛЭ . СНІЫЭЫАМЕ , 
ДОІЫСНІЫ) . СОММЕЫТАКУ РКОМ ДОІЫРАКЕЫТ, ДОІЫСНІЬБ ИНЕКЕ ДОІЫРАКЕЫТ . Р_:т = 
ДОІЫСНІІЛЭ. Р_ІБ( + ) . 

Результат работы этого запроса показан на рис. 7.28. 


В 



п 

ЕШИШ® 

ри 

ш 


в 

в 

@ 

в 


МША N0 СОММЕЫТ ЗиѴА ш і N0 СОММЕЫТ ■ 

в 

РЕТН N0 СОММЕЫТ Ш Щ >У*: 


Рис. 7.28. Результат при использовании условии связывания [.ей Оиіег Лоіп 

Как видно из рисунка, количество строк больше, чем при использовании 
условия Ериаі іоіп. При этом данные из родительской таблицы показаны 
полностью. Из дочерней же таблицы отображены только те, которые имеют 
полное соответствие ключевых значений. Если использовать условие Кі§М 
Оиіег іоіп, то запрос выглядит так: 

ЗЕЬЕСТ ДОШРАКЕЫТ.ЫАМЕ, ДОІЫРАКЕЫТ .СОММЕЫТАКУ, ДОІЫСНІІЛЭ. СНІІЛЭЫАМЕ, 
ДОІЫСНІІЛЭ. СОММЕЫТАКУ РКОМ ДОІЫРАКЕЫТ, ДОІЫСНІІЛЭ ИНЕКЕ ДОІЫРАКЕЫТ. Р_П) ( + ) 

= доіысніілэ. р_ю 


т 


р 

• :>шд 

В 


ш 

5УЕТЦЫА N0 СОММЕЫТ , АЬЕХ " N0 СОММЕЫТ 

Ід 
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ѴА5ІШ N0 СОММЕЫТ ЕСОН N0 СОММЕЫТ 

ѴАЗІШ ЫО СОММЕЫТ 10А ЫО СОММЕЫТ 
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Рис. 7.29. Результат обработки запроса с использованием условия 
связывания таблиц ВідЫ Оиіег Лоіп 

Кроме символа + в ряде случаев для определения Ьей и К.І§ІИ Оиіег іоіп 
может быть использован символ *. Синтаксис запроса при этом несколько 
меняется и выглядит так: 

□ для Ьей Оиіег іоіп 

8ЕІЛЗСТ ДО ІЫРАКЕЫТ .ЫАМЕ, ДОІЫРАКЕЫТ.СОММЕЫТАКУ, ДОІЫСНІІЛЭ . СНІІЛЭЫАМЕ , 
ДОІЫСНІІЛЭ. СОММЕЫТАКУ РКОМ ДОІЫРАКЕЫТ, ДОІЫСНІЬБ ИНЕКЕ ДОІЫРАКЕЫТ . Р_ІБ* 
= ДОІЫСНІІЛЭ.Р_ІБ 














































Связь с базами данных 


193 


□ для Кі§1Д Оиіег .Іоіп 

ЗЕЬЕСТ ДОШРАКЕОТ.ЫАМЕ, ДОШРАКЕЦТ. СОММЕ№ГАКУ ^ ОГОШСНІШ.СНІЬШАМЕ, 
ДОШСНІШ.СОММЕКГГАКУ РКОМ ДОШРАКЕЫТ, ДОШСНІЬБ ШЕКЕ ДОІЫРАКЕЫТ.Р_ІЬ 
= *ДОШСНІЬБ.Р_ІВ 

Для работы с Місгозой Ассезз синтаксис запроса должен значительно отли¬ 
чаться от ранее описанных вариантов. Условие будет выглядеть так: 

РКОМ ДОШРАКЕЫТ ЬЕРТ ООТЕК ДОШ ДОШСНІШ ОЫ ДОІЛРАКЕЫТ . Р_ІБ = 

дотсніьв.р_іо 

При работе с большим количеством связанных таблиц существует вероят¬ 
ность того, что текст запроса будет очень длинным и, как следствие, труд¬ 
ным для восприятия. Для того чтобы упростить структуру запроса и укоро¬ 
тить его длину, можно воспользоваться псевдонимами таблиц, которые 
могут быть короткими. Принцип задания псевдонима таблицы таков: 

РКОМ ДОШРАКЕЫТ Т1, ДОШСНІШ Т2 

Как следствие, весь запрос будет выглядеть так: 

ЗЕЬЕСТ Т1.ЫАМЕ, Т1.СОММЕЫТАКУ, Т2. СНІЬВЫАМЕ, Т2.СОММЕЫТАКУ РКОМ 
ДОШРАКЕЦТ Т1, ДОШСНІЬБ Т2 МНЕКЕ Т1.Р_ІБ = Т2. Р_ІБ 

Кроме возможности сделать запросы более короткими и изящными, псев¬ 
донимы позволяют упоминать одну и ту же таблицу в предложении РКОМ 
несколько раз. Пример такого запроса: 

ЗЕЬЕСТ С1.СОООЗ, 02.С00БЗ, СЗ.СООБЗ РКОМ <30005 01, 00005 02 00005 03 
ИНЕКЕ 01. Ргісе=100 АРГО О2.Ргісе=500 СЗ.Ргісе=300 

Однако при выполнении такого запроса необходимо учитывать то, что ре¬ 
зультирующий набор данных будет содержать избыточную информацию. 


Упражнение 7.9 

1. Используя имеющуюся у вас базу и набор данных, напишите запрос, вы¬ 
дающий список заказов с указанием имен заказчика и продавца, и соз¬ 
дайте отчет. 

2. Напишите запрос, выдающий пары клиентов из одного города, и создай¬ 
те отчет. 

3. Напишите запрос, выдающий пары клиентов из одного города. Повторы 
типа "Иванов-Петров" — "Петров-Иванов" исключите. Создайте отчет. 

Часто возникает необходимость получить данные, условия фильтрации 
в которых формируются с помощью другого запроса. Для реализации такой 
обработки можно использовать механизм вложенных $<ДЬ-запросов. Одним 
из вариантов вложенных ЗОЬ-запросов является операция сравнения дан¬ 
ных в предложении ѴѴНЕКЕ. При описании сравнения можно использовать 
ключевые слова: 

□ АМУ; 
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□ АЬЬ; 

□ 80МЕ. 

Для сравнения характеристик данных операторов рассмотрим два запроса. 

ЗЕЬЕСТ * РЕОМ СООЬЗ МНЕКЕ РКІСЕ*ОИАШ'ІТУ = АЫУ (ЗЕЬЕСТ ЗЦММ РКОМ ОКО 
ШЕЕЕ ОАТЕО < ТО_БАТЕ(’19/01/2001 1 ,’ОО/ММ/УУУУ’)); 

ЗЕЬЕСТ * том ОООБ8 ШЕЕЕ РЕІСЕ*ОИАЫТІТУ < АЬЬ (ЗЕЬЕСТ ЗЦММ РКОМ ОЕГ) 

ИНЕКЕ БАТЕО < ТО_БАТЕ(’19/01/2001',’ОО/ММ/УУУУ’)); 

^ Примечание ^ 

Ключ ЗОМЕ используется как синоним АЫѴ. 

Результат работы первого запроса будет содержать записи, в которые произ¬ 
ведение РШСЕ*01ІА1ЧТІТѴ равно какому-нибудь значению поля ЗІІММ 
в множестве записей, отобранных при выполнении подзапроса. Результатом 
работы второго запроса станет набор записей, в которые произведение 
РК.1СЕ*рЕГАЫТ1ТУ меньше любого значения поля 81ЛЙМ во множестве 
записей, отобранных при выполнении подзапроса. 

В качестве другого варианта вложенных 8фЬ-запросов можно рассмотреть 
установку фильтрации данных по списку значений, получаемых другим 
8 (^--запросом. Для этого используется оператор Ш или N07 Ш. Запрос, 
использующий оператор ІИ и вложенный запрос, выглядит так: 

ЗЕЬЕСТ * том 00003 ШЕЕЕ ОКОЕКЮ Ш (ЗЕЬЕСТ ОКОЕКЮ РКОМ ОКО ИНЕКЕ 
БАТЕО<ТО_ОАТЕ( ' 19/01/2001’, ’ОО/Ш/УУУУ' ) ) 

Иногда требуется получить данные из одной таблицы, но при этом прове¬ 
рить наличие связанных данных в дочерней. Простейшим примером может 
служить такой вариант, когда есть таблица, содержащая информацию о ме¬ 
неджерах и связанная с ней таблица заказов. Необходимо получить инфор¬ 
мацию о тех менеджерах, которые выписали хотя бы один заказ. Для этого 
можно воспользоваться обычным запросом с использованием ЮШ, но не 
всегда это удобно, так как может возникнуть избыточность в возвращаемом 
наборе данных. С помощью предложения ЕХІ8Т8 реализация запроса по¬ 
зволит сделать запрос более качественным. Запрос будет выглядеть так: 

ЗЕЬЕСТ ЫАМЕ РКОМ ЗАЬЕЗРЕОРЬЕ МНЕКЕ ЕХІ5Т5 (ЗЕЬЕСТ * РКОМ ОКО МНЕКЕ 
ОКО. ЗАЬЕЗРЕОРЬЕЮ= ЗАЬЕЗРЕОРЬЕ. ЗАЬЕЗРЕОРЬЕЮ) 

Упражнение 7.10 

1. Создайте отчет на основе запроса, использующий подзапрос, выдающий 
список заказов, которые принял продавец Иванов. 

2. Создайте отчет на основе запроса, выдающего продавцов, сумма заказов 
которых выше среднего. 

3. Создайте отчет на основе запроса, использующего подзапрос, выдающий 
продавцов, имеющих более одного клиента. 
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4. Создайте отчет на основе запроса, выдающего клиентов, сумма на счету 
которых не меньше, чем сумма на счету любого клиента из Москвы. 

Кроме возможности написания запросов с подзапросами существует также 
механизм объединения нескольких запросов в один. Для этого используются 
предложения ІЖІСЖ или ІЖІСЖ АЬЬ. Структура такой конструкции пока¬ 
зана на схеме 7.7. 

ЗЕІ.ЕСТ ...-[АН]-»ЗЕ1ЕСТ ...- »Ш1І0М [АН]... 

Схема 7.7. Структура запроса с ІІЫІОЫ 

При построении такого запроса необходимо учитывать то, что структура 
возвращаемого результата формируется первым запросом. Все последующие 
запросы, после ЫЫІОЫ, должны возвращать такое же количество полей, что 
и первый запрос, и типы данных должны совпадать соответственно. Воз¬ 
можные варианты запросов могут выглядеть так: 

ЗЕЬЕСТ ЫАМЕ РКОМ ЗАЬЕЗРЕОРЬЕ ИНЕКЕ ЗАЬЕЗРЕОРЬЕ. СІТУ = 

' Ьопсіоп ' ШІОЫ ЗЕЬЕСТ ЫАМЕ ЕЮМ СХГЗТОМЕК ИНЕКЕ ОТ5ТОМЕК. СІТУ = 

' Ьопсіоп ' 

ЗЕЬЕСТ ЫАМЕ, СІТУ ЕКОМ ЗАЬЕЗРЕОРЬЕ ИНЕКЕ СОШТКУ = 

'Киззіа' ШІОЫ ЗЕЬЕСТ ЫАМЕ, СІТУ ЕКОМ С05Т0МВК ИНЕКЕ СОШТКУ = 'Киззіа' 

Для сортировки данных в таких запросах можно также использовать пред¬ 
ложение ОІШЕК. ВУ со списком полей. В данном случае можно использо¬ 
вать порядковый номер поля из списка ЗЕЬЕСТ вместо явного указания 
имени поля, по которому будет выполняться сортировка. Этот механизм 
поддерживается не всеми СУБД. 

ЗЕЬЕСТ ЫАМЕ, СІТУ ЕКОМ ЗАЬЕЗРЕОРЬЕ ИНЕКЕ СОШТКУ = 

'Киззіа' ШІОЫ ЗЕЬЕСТ ЫАМЕ, СІТУ ЕКОМ СИЗТОМЕК ИНЕКЕ СОШТКУ = 

'Киззіа' ОКОЕК ВУ 2 

Также за счет использования предложения ІЖІСЖ можно организовать за¬ 
прос, в котором одна часть исключает строки выбранные в другой. 

ЗЕЬЕСТ 'Клиенты из России '|(ЫАМЕ ЕКОМ СЦЗТОМЕК ИНЕКЕ СОШТКУ = 

'Киззіа' ШІОЫ ЗЕЬЕСТ 'Другие клиенты ' | |ЫАМЕ ЕКСМ СТ15ТСМЕК ИНЕКЕ СОШТКУ ! = 
'Киззіа' 


Упражнение 7.11 

Напишите запрос, выдающий клиентов жителей Лондона, сумма на счету 
которых не меньше 1000, и клиентов жителей Москвы, сумма на счету ко¬ 
торых не меньше 500, и постройте на его основе отчет. 
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7.6. Использование хранимых процедур 
в Сгузіаі Керогіз при построении отчетов 

Как уже говорилось ранее, в Сгузіаі КероЛз 9 можно использовать не только 
таблицы и представления в качестве источников данных, но и хранимые 
процедуры. Рассмотрим данную возможность на основе СУБД Огасіе и соз¬ 
дадим набор элементов, часть из которых потом будет использована в Сгузіаі 
КероЛз 9. Для начала реализуем таблицу и заполним ее данными. 



СКЕАТЕ ТАВЬЕ ТезЬ_ТаЫе 
(Ю питЬег(5), 

ЕігзСпате ѵагсЪаг2 (30), 
ЬазЬпате ѵагсЬаг2(30) , 
ВігСМау сІаСе) ; 



ШЗЕКТ ЮТО ТезС_ТаЫе ѴАШЕЗ 

(1, 'СЪгізЬорЬег ', 'Лопез', ' ОІ-ЬГоѵ-70 '); 

ШЗЕКТ ШТО ТезС_ТаЫе ѴАЬЦЕЗ 

(2, 'Магіа' , 'МагзЬаІІ', '02-Лап-77'); 

ШЗЕКТ ЮТО ТезЬ_ТаЫе ѴАШЕЗ 

(3, 'Лопайіап', 'СашрЬеІІ', '09-Аид-75'); 

ШЗЕКТ ШТО ТезЬ_ТаЫе ѴАШЕЗ 

(4, 'Лиііе', 'Садпоп', '23-Сес-72'); 

ШЗЕКТ ЮТО ТезЬ_ТаЫе ѴАШЕЗ 

(5, 'Баегпоп', 'ТЬотрзоп', '11-РеЬ-б9'); 



СКЕАТЕ ОК КЕРЬАСЕ РАСКАСЕ ТезЬ_Раскаде 

АЗ ТУРЕ Тез Ь_Туре 13 КЕЕ СШЗОК КЕТЦКЫ ТезЬ_ТаЫе%К0ИТУРЕ; 
ЕШ ТезЬ_Раскаде; 

/ 



СКЕАТЕ ОК КЕРЬАСЕ РКОСЕШКЕ Тез Ь_РгосеДиге ( 
ТезЬ_Сигзог Ш ОЦТ ТезЬ_Раскаде.ТезЬ_Туре, 
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ТезЬ_РагатеЬег Ш Тезь_ТаЫе.1Б%ТУРЕ) 
АЗ 

ВЕСШ 

ОРЕМ ТезЬ_Сигзог ГОК 

ЗЕЬЕСТ * РКОМ ТезЬ_ТаЫе 

МНЕКЕ Тез Ь_ТаЫе. ІБ = ТезЬ_РагатеІ:ег; 

ЕЫБ ТезЬ_Ргосе<Зиге; 

/ 


После создания описанных объектов базы данных можно перейти к работе 
с Сгукіаі КероЛз 9 и настроить параметры среды на работу с хранимыми 
процедурами, как описано в разд. 7.3. Далее можно приступать к созданию 
отчета с использованием хранимых процедур. Так как Сгуйаі КероЛк 9 по¬ 
зволяет устанавливать соединение с СУБД Огасіе и с помощью СШВС и на¬ 
прямую, выберите наиболее удобный для вас вариант. На рис. 7.30 показано 
диалоговое окно Ба(а (Данные) из которого осуществлено подключение 
к Огасіе напрямую. 








Оаіа 

СИоозе 1Не гіаіа уои юапі Іо іерогі оп. 




АѵаііаЫе ОаЛа $оигсе$: 


ЗеІесіесІТаЫек 


ш-Озоовсроо) 

Ш'СЗОІар 
Ш ОЗОЬЕ 0В (А00) 

В ^іОіасІе Зеіѵеі 

: % Маке Мею Соппесііоп 
. В Ц} М0ѴВА5Е 

і'Ш Асісі Соттапд 
шЦ СЕДОМ 
яДІОВЗИМР 
В-ЦОЕШ 
• аЦт аЫе$ 

; ев Зіоіесі Ріосегіиге$ 


; В уЦІ ОиаМіегз 

; в1|оемі$_смр 
га>Й оиии 
аЯривис 
вв$ѵ$ 

® И вузтем 

Й иІІ'л'еЬ/ІІЗ |_од РіІе$ 

Й С]хВазе 

® иД Моге Ва&а Зошсез 




<$вд. | МехЕ> • | ЕігоН | СапсеІ [ Йеір | 


Рис. 7.30. Подключение к СУБД Огасіе 
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Выбираем схему, в которой были созданы описанные выше элементы. 
В разделе Віогегі Ргосегіигез (Хранимые процедуры) выбираем хранимую 
процедуру ТЕ8ТРКОСЕОІЖЕ и добавляем ее в отчет в качестве источника 
данных. Так как процедура имеет параметры, автоматически появляется 
диалоговое окно Епіег Рагатеіег Ѵаіиев (Введите значения параметров), 
в котором можно установить требуемые значения так, как показано 
на рис. 7.31. Эти параметры автоматически будут включены в отчет и затем 
их можно будет менять. 



ІСпІег Рагатеіег Ѵаіиеі 


ТЕ5Т.РАЙАМЕТЕЙ 


Раіатеіеі РіеЬк 


Рис. 7.31. Установка значений параметров для хранимой процедуры 


Дальнейшая работа с полученными данными выполняется так же, как с таб¬ 
лицами и представлениями. То есть можно использовать формулы, функ¬ 
ции, группировку и т. п. 

Та же самая хранимая процедура может быть реализована с помощью пакета. 


СКЕАТЕ ОК КЕРІАСЕ РАСКАСЕ Те5р_Раскаде 

АЗ ТУРЕ ТезР_Туре 13 КЕЕ СТЖ80К КЕТОКЦ ТезР_ТаЪ1е%К0МТУРЕ; 
РКОСЕГОКЕ ТезР_Ргоседиге ( 

ТезР_Сигзог Ш ОЧТ ТезР_Туре, 
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ТезІщРагатеБег Ш Тезк_ТаЫе. ІВ%ТУРЕ 
) ; 

ЕЖ) Тезк_Раскаде; 

/ 


_ . 

Создание тела пакета 


СЯЕАТЕ ОЯ КЕРІАСЕ РАСКАСЕ БОБУ Тез Ь_Раскаде 
А8 

РЯОСЕВШЕ Тезк_Ргосе<Зиге ( 

Тезк_Сигзог Ш ОЧТ Тезк_Туре, 

Тезк_Рагатекег Ш Тез!:_ТаЫе. ІВ%ТУРЕ 

) 13 

ВЕСШ 

ОРЕЦ Тезк_Сигзог РОЯ 

ЗЕБЕСТ * РЯОМ Тезк_ТаЫе 

ШЕЯЕ Тезк_ТаЫе. ІБ = Тезь_РагатеЬег ; 

ЕЖ Тезк_Ргосе<іиге; 

ЕЖ Тез(:_Раскаде; 

/ 


Единственное ограничение, которое накладывается на использование хра¬ 
нимых процедур, это запрет на организацию связи между процедурой и таб¬ 
лицами или представлениями, т. е. в одном отчете нельзя одновременно ис¬ 
пользовать хранимую процедуру и таблицу. 

Упражнение 7.12 

Создайте процедуру, которая возвращает цифровые данные в строковом 
формате прописью, и включите ее в отчет. 

7.7. Изменение местоположения полей, 
проверка базы данных и смена драйвера 

Иногда возникает необходимость во внесении изменений именно в ту базу, 
для которой вы создаете отчет. Встречаются случаи, когда база данных нахо¬ 
дится в состоянии непрерывного изменения, т. е. динамически меняется по 
мере создания отчета. Или, возможно, создается отчет для тестовой базы, 
а затем выполняется его связывание реальной базой данных. Желательно 
иметь возможность контролировать подобные изменения по мере обновле¬ 
ния базы данных, без необходимости повторного создания каких-либо 
свойств или функций в отчете. 
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Одним из видов таких изменений базы данных может быть переименование 
полей разработчиком или администратором базы данных. Сгузіаі КероЛз 9, 
обнаружив эти изменения, дает возможность изменить ссылки на поля 
в отчете, таким образом, новые имена полей можно автоматически связать 
с созданными ранее. Такая обработка полей освобождает разработчика от 
необходимости добавлять к отчету новые поля или модифицировать форму¬ 
лы, ссылающиеся на измененные поля. 

Есть несколько способов согласовать изменения, сделанные в базе данных: 

□ проверить базу данных; 

□ указать местонахождение базы данных. 

Все они описаны в этой главе. 


7.7.1. Проверка или изменение местоположения 
базы данных 

При внесении изменений в структуру базы данных, когда изменяются имена 
полей, типы данных и т. п., при перемещении базы данных в другое место 
или при необходимости привязки своего отчета к другой базе данных, у раз¬ 
работчика появится необходимость в использовании функций Сгузіаі 
КероЛз 9, распознающих эти изменения. 

В случае, когда разработчик базы данных добавил новые поля, удалил ста¬ 
рые, изменил имена или типы данных существующих полей, при открытии 
отчета, основанного на этой информации, внесенные изменения не будут 
распознаны в автоматическом режиме. Даже после обновления отчета 
Сгузіаі КероЛз 9 не обнаружит этих изменений. Единственный выход в дан¬ 
ной ситуации — это сделать проверку соответствующей базы данных. 
Для этого необходимо выполнить команду меню ОаіаЪазе | Ѵегііу ОаіаЪазе. 
Если база данных не была изменена, то появится сообщение, показанное 
на рис. 7.32. 


Рис. 7.32. Проверка базы данных. Изменений в базе данных не обнаружено 

В противном случае, если база данных была изменена, появится сообщение 
подобное тому, которое изображено на рис. 7.33. 
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Рис. 7.33. Сообщение об изменении базы данных 

При нажатии на кнопку ОК СгузіаІ Керогіз 9 вновь прочитает структуру ба¬ 
зы данных и внесет необходимые изменения в имена таблиц, имена полей и 
типы данных. При запуске РіеШ Ехріогег (Просмотрщик полей), можно бу¬ 
дет увидеть произведенные изменения. Кроме того, если в отчете использо¬ 
вались связанные между собой таблицы и структура этих таблиц значитель¬ 
но изменилась, то, скорее всего, придется заново связать эти таблицы при 
помощи окна ОаІаЬазе Ехрегі (Эксперт базы данных). Если изменились 
имена полей, то появится диалоговое окно Мар РіеМ§ (Карта соответствия 
полей), о котором будет рассказано далее. 



В 5еІ Оаіазоигсе Іосаііоп 




СКапде <Ие Іосаііоп Ы |Нів сіаіа зоиісе Ьу зеіесііпд ІИе сиігепі сіаіаЬазе (ог ІаЫе] апр сЬоозіпд (Не сЫаЬазе (оі ІаЫв) Іо 
геріасе 'Л ЮІІН. ТНеп сііскІІрсіаІе. . ■■ ■ '■ ■ ■ ■■ ■.- - ■ ■ 

Сипел! ОаІаЗоигсе: - . Д ". г ‘ з 


Ргорегііез 
Ш® ЗАКАЗЫ 
Ш~і ПОКУПАТЕЛИ 
Й-Ш ПРОДАВЦЫ 
Ш Щ ТОВАРЫ 


Неріасе «Ж 
Ѳ □ Сиггепі Сотесііолз 
СТЬДЯеоозіюш 
Я-рУ)Раѵогі(ез 
Й П'ІНІзІот 

В | Сгеаіе Ием Сотесііоп 


Рис. 7.34. Окно, позволяющее изменить местоположения источника 
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Иногда приходится менять скорее тип, а не имя базы данных. К примеру, 
часто бывает, что отчет, изначально разработанный для настольной базы 
данных, впоследствии используется для сетевого источника. В этом случае 
необходимо указать новое местонахождение базы данных и, возможно, из¬ 
менить тип библиотек, используемых для соединения с источником. Для 
этого требуется вызвать с помощью команды меню БаІаЪазе | 8еі Ваіаяоигсе 
Ьосаііоп окно 8е( Баіазоигсе Ьосаііоп, показанное на рис. 7.34. 

Как видно из этого рисунка, имеется возможность быстро изменить не 
только путь к источнику данных, но и его тип. 

7.7.2. Согласование старых полей 
с новыми именами 

Изменения в базе данных могут привести к несоответствиям с именами по¬ 
лей созданного ранее отчета. Например, отчет мог быть разработан для базы 
данных МісгозоД Ассе$$, содержащей поле Ассоипі ІѴитЬег (пробел между 
словами важен для Сгузіаі Керогіз), а реальности может понадобиться этот 
же отчет, но для работы с базой данных М8 80Ь 8егѵег, в которой это поле 
называется АссоипМѴитЬст, здесь пробел заменен знаком подчеркивания. 

Что делать в случае изменения имен таблиц 

Если разработчик или администратор базы данных изменит имя таблицы, 
при очередной попытке обновить отчет поступит сообщение об ошибке, 
указывающее, что данная таблица не может быть найдена. К сожалению, 
обновление отчета или проверка базы данных не решит эту проблему: сооб¬ 
щение будет повторяться, а отчет нельзя будет правильно сформировать. 

Для решения этой проблемы следует выполнить следующие простые шаги: 

1. Выполните команду меню ОаІаЬазе | 8е( Баіаяоигсе ЬосаВоп. В открыв¬ 
шемся диалоговом окне 8е( Баіазоигсе Ьосаііоп (Установка местонахож¬ 
дения источника данных), показанном на рис. 7.34, в разделе Сиггепі 
Баіа 8оигсе (Текущий источник данных), выберите таблицу, имя которой 
было изменено. 

2. В окне Керіасе \ѵШі укажите новый источник данных для выбранной таб¬ 
лицы. 

Что делать в случае изменения полей таблиц 

После выполнения перечисленных действий появится окно Мар Ріеійк 
(Карта соответствия полей), которое показано на рис. 7.35. 

Список полей базы данных, предлагаемых для сопоставления полю отчета, 
меняется в зависимости от того, установлен ли флажок МаІсИ Туре 
(Совпадение типа) в правой части диалогового окна. Если флажок установ- 
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лен, то будут показаны только поля того же типа данных (строка, число, 
дата и т. д.), что и выделенное поле отчета. Это помогает избежать невер¬ 
ного сопоставления, например, строкового поля в отчете числу или дате 
в новой базе данных, хотя иногда может потребоваться и такое сопоставле¬ 
ние. Из-за несоответствия типов данных в правом списке может не оказать¬ 
ся поля, которое необходимо обработать. Например, при переходе от базы 
данных МІСГ 080 Й Ассевз к базе данных 5()І_ Зегѵег, скорее всего не будут 
найдены поля, соответствующие полю валюты базы данных Ассе$$. В этом 
случае необходимо снять флажок МаІсЬ Туре (Совпадение тип), и найти 
поле для сопоставления. 


! Мар РіеІе(§ 


Уптарресі РіеИ$ 


т 


. X] 


Е 1 Верогі РіеИ$ 

Я ЕШО Си$іотеі ^ 
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: га 

та Сопіасі Еіг$1 Мате 

аэ 1Л5ТМАМЕ 

та Сопіасі І_а$ІМате _ 


та Сопіасі Т іііе 
та Сопіасі Розіііоп 
та Агісігеззі 

та А(Мге$$2 т] 

±1__! лі 


Маг 


Г? Ма(сІЦур* 


МарресіРіеИз 


Б 9 Верогі Ріекі$ 

Ш ТЕЗТ_ТАВ1_Е 

Б # 0 ѴРіодмт Рііе$\Сгу$Ы Оесыо 


. 

< і 

Л - : '■ ±1 ■ 






ОК *| Сапсеі | Ьіе'Р | 


Рис. 7.35. Окно Мар Ріеісіа, позволяющее сопоставить поля 
существующего отчета с новыми полями базы данных 


При первом открытии диалогового окна некоторые поля могут уже присут¬ 
ствовать в двух нижних списках. Левый нижний список показывает поля 
отчета, которые уже имеют соответствующие поля в новой базе данных. 
В случае сопоставления полей из верхних списков, они также будут пере¬ 
мещены в нижние списки. Если существующее сопоставление предложено 
самим Сгузіаі КероПд 9 на основании совпадения имен полей или произош¬ 
ло ошибочное сопоставление полей, можно действовать так. Выделить поле 
в левом нижнем или в правом нижнем списке, при этом в другом списке 
будет выделено сопоставленное поле. Затем можно нажать кнопку Ишпар 
(Отменить связь полей), чтобы отменить сопоставление полей и вернуть их 
в верхние списки. 













204 


Глава 7 


Закончив сопоставление полей, необходимо нажать кнопку ОК, диалоговое 
окно Мар Ріеійз (Карта соответствия полей) будет закрыто. Затем СгузіаІ 
Керогіз 9 свяжет сопоставленные поля с новой базой данных. Если в других 
таблицах есть ненайденные поля, для каждой из них будет выведено диало¬ 
говое окно Мар Ріеісіз (Карта соответствия полей). 

Т. Примечание ^ 

Все поля, которые не существуют в измененной базе данных, должны быть 
заменены новыми полями. Если вы не сопоставите новые имена полей старым, 
старые поля и объекты, на которых они основаны, будут удалены из вашего 
отчета! 


7.8. Возможности по настройке отчетов 
для выполнения ЗОЬзапросов, 
формируемых СгузіаІ Рерогіз 
на стороне сервера базы данных 

В связи с тем, что в большинстве случаев выполнение функций на стороне 
сервера происходит значительно быстрее, чем на стороне клиента, СгузіаІ 
Кероііз 9 имеет ряд возможностей по настройке для обработки запросов на 
сервере. 

Для того чтобы выполнять группирование на сервере, а не группировать 
данные в СгузіаІ Кероііз 9 после их выборки, необходимо, чтобы отчет удов¬ 
летворял следующим требованиям: 

□ должна быть выбрана опция Регіопп Сгоирііщ Оп 8егѵег (Выпол¬ 
нять группирование на сервере), которая задается через команду меню 

ОаіаЬазе | РегГогш Сгоиріп§ Оп Зегѵег; 

□ отчет должен содержать условие группирования; 

□ желательно, чтобы все имеющиеся секции Оеіаііз были скрыты, хотя 
в ряде случаев они скрываются автоматически; 

□ сложные формулы, вычисляемые в секции Беіаііз, недопустимы. Необхо¬ 
димо использовать 50Ь-выражения; 

□ не должно быть вычисления кумулятивных значений; 

□ агрегатные функции типа Аѵега§е и Оізііпсі использовать нельзя. Воз¬ 
можны только варианты функций, которые имеют аналоги в 80Ь. Это 
51Ж, СОЕПЧТ и т. п.; 

□ параметры, задаваемые через Сгоир 8огі Ехрегі (Эксперт группировки 
и сортировки данных), и специальные типы группировки не должны 
быть задействованы. 
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Если отчет удовлетворяет перечисленным условиям, в ЗОЬ-запрос добавля¬ 
ется предложение ОКОЕГР ВУ, которое позволяет выполнить группировку 
на сервере. 

Г^~ Примечание 

Как видно из перечисленного списка требований, для того, чтобы отчет обраба¬ 
тывал запрос на сервере, а не на клиентском месте, необходимо сильно огра¬ 
ничить использование функциональности Сгузіаі РероПз 9. Однако в ряде слу¬ 
чаев, такие возможности могут значительно ускорить обработку данных. 

В случае если выбрана опция ІІзе Іпгіехе§ Ог Зегѵег Рог 8реей (Использовать 
индексы или сервер для ускорения обработки данных) на вкладке ИаІаЬазе 
диалогового окна Орііопз, которое вызывается с помощью команды меню 
РПе | Орііопз, в ЗфЕ-запрос автоматически добавляется предложение 
ОІШЕК. ВѴ. Кроме того, иногда для настольных источников данных будет 
формироваться ЗС^Ь-запрос, оптимизированный под использование меха¬ 
низмов обработки данных на выбранном сервере. 

Упражнение 7.13 

Включите опции Сгузіаі Керогіз 9, относящиеся к настройке механизмов 
работы с базами данных, и модифицируйте конструкцию отчета. Просмот¬ 
рите результирующий запрос, выполнив команду меню ОаІаЬазе | 8Ьо\ѵ 8(^1, 
<2иегу. 






Глава 8 



Распространение отчетов 


8.1. Экспорт отчетов 

Часто возникает потребность получить готовый отчет в формате, который не 
потребует установки Сгузіаі Рерогіз 9 или его компонентов на машине поль¬ 
зователя. При этом желательно, чтобы элементы форматирования сохраня¬ 
лись как можно точнее. Сгузіаі Керогіз 9 позволяет выполнять экспорт отче¬ 
тов в любом из перечисленных форматов: 

□ СЬагасІег-зерагаіесІ ѵаіиез 

□ Сотта-зерагаіесі ѵаіиез (СЗѴ) 

□ Сгузіаі КероПз (КРТ) 

□ Місго8оГі® Ехсеі 

□ НТМЬ 4.0 

□ НТМЬ3.2 

□ СЮВС 

□ АёоЪе АсгоЬаІ (Р19Р) 

□ Кесогй зіуіе 

□ Верой. ОеГіпШоп 

□ КісЬ Техі Рогшаі 

□ ТаЬ-зерагаІеё ІехС 

□ ТаЬ-зерагаСей ѵаіиез 

□ Техі 

□ \Уогсі Гог \Ѵіпс1о\ѵз ёоситеМ 

□ ХМЬ 

Для то го ч тобы приступить к выполнению экспорта, необходимо нажать 
кнопку [^,1 или выполнить команду меню Рііе | Ехрогі. Появится диалоговое 
окно Ехрогі, показанное на рис. 8.1. 
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Рис. 8.1. Диалоговое окно настройки параметров экспорта 


В этом окне можно выбрать параметры экспорта отчета. Из выпадающего 
списка Рогпіаі выбирается требуемый формат. Кроме этого, имеется воз¬ 
можность выбора механизма сохранения или обработки экспортирован¬ 
ного отчета. Список возможных вариантов обработки представлен в поле 

Иезйпаііоп: 

□ АррІісаГіоп — можно сразу открыть результат экспорта с помощью при¬ 
ложения. Например, при экспорте в \Ѵогб или КТР автоматически запус¬ 
тится ѴѴогсі Гог \Ѵіпбо\ѵ$ и покажет отчет; 

□ ІЭізк Ше — сохранение в виде файла, который потом можно обрабаты¬ 
вать; 

□ ЕхсЬап§е Роігіег — сохранение в папку МісгозоГі: Ехс1іап§е; 

□ Еоіиз Ботіпо — сохранение в базе данных ЬоШз Оотіпо; 

□ Еоіиз Оотіпо Маіі — отправка электронной почты посредством ЬоШз 
Оотіпо; 

□ МісгозоЙ Маіі (МАРІ) — отправка электронной почты посредством ме¬ 
ханизма фирмы Місгозой. 

После того как выбран формат экспорта и указан механизм его обработки, 
можно нажать кнопку ОК. Для большинства форматов непосредственно пе¬ 
ред выполнением экспорта появится диалоговое окно Ехрогі Орйопз 
(рис. 8.2). Используя настройки в этом окне, можно определить диапазон 
экспортируемых страниц: 

□ АІ1 — все страницы отчета; 

□ Ра§е Кап§е Ргот: То: — только страницы, номера которых попадают 
в указанный в полях диапазон. 

После того как определен диапазон экспортируемых страниц и нажата 
кнопка ОК, появляется стандартное окно, в котором необходимо указать 
каталог и имя создаваемого файла, если выбрана опция Бівк Рііе. Для других 
опций надо будет указать адресата, которому отправляется отчет по почте, ли¬ 
бо каталог Місгозой ЕхсЬап§е. После выполнения этих действий открывается 
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диалоговое окно Ехрогііп§ Кесоггіз, которое показывает прогресс экспорта 
данных. Внешний вид окна показан на рис. 8.3. 




-РадеВапде—- 
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Рис. 8.2. Окно Ехрогі Орііопз 


щштшшш ш * 



Рис. 8.3. Окно Ехроіііпд Несогсіз 


В случае экспорта отчета в формат М8 Ехсеі 97-М8 Ехсеі 2000 должно поя¬ 
вится диалоговое окно Ехсеі Рогшаі ОрВопх, которое показано на рис. 8.4. 
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Рис. 8.4. Окно Ехсеі Рогтаі ОрОопз. Настройка параметров экспорта 
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Параметры настройки в данном окне можно разделить на группы: 

□ Соіитп ѵѵігіііі — настройка параметров ширины колонок; 

□ Ра§е гап§е — выбор диапазона экспортируемых страниц отчета; 

□ дополнительные параметры. 

Параметры, относящиеся к ширине экспортируемых колонок, содержат сле¬ 
дующие варианты настроек: 

□ Соіитп ѵѵібіЬ Ъазегі оп оідесіз іп ІЬе — ширина колонок определяется ши¬ 
риной объекта из выпадающего списка: 

• \Ѵ1ю1е Кероіі — ширина колонок определяется шириной объектов 
всего отчета; 

• Керогі Неабег — ширина колонок определяется шириной объектов, 
находящихся в секции Кероп Неабег; 

• Огоир Неабег #Ы — ширина колонок определяется шириной объектов, 
находящихся в секции Огоир Неабег. N заменяется на номер секции; 

• Огоир Рооіег #Ы — ширина колонок определяется шириной объектов, 
находящихся в секции Огоир Рооіег. N заменяется на номер секции; 

• Ра§е Роогег — ширина колонок определяется шириной объектов, на¬ 
ходящихся в секции Ра§е Рооіег. 

□ Сопвіапі соіитп ѵѵібіЬ (іп роіпіз) — одинаковая ширина для всех колонок, 
ширину колонки необходимо вписать в поле. 

Секция Ра§е гаіще содержит те же настройки, что присутствуют в диалого¬ 
вом окне Ехрогі Орііопв, показанном на рис. 8.2. 

Дополнительные параметры экспорта позволяют выполнить следующие дей¬ 
ствия: 

□ Ехрогі Ра§е Неабег апб Ра§е Рооіег — выполнять экспорт данных, кото¬ 
рые содержатся в секциях отчета Ра§е Неабег и Ра§е Рооіег; 

□ Сгеаіе ра§е Ьгеакя Гог еасЬ ра§е — формировать разрыв страницы в итого¬ 
вом документе; 

□ Сопѵегі (іаіе ѵаіиез Іо 8Ігіп§ — выполнять конвертацию полей типа Паіе 
в строку. 

После выполнения настроек в окне ЕхсеІ Рогтаі Орііопв потребуется вы¬ 
полнить те же действия, что описаны выше для экспорта в другие форматы. 

Помимо экспорта данных из отчета в файл выбранного формата существует 
возможность экспорта с помощью ООВС. Данный механизм предполагает 
создание в выбранном ООВС-источнике новой таблицы либо использова¬ 
ние уже существующей таблицы для сохранения информации из отчета. 
При экспорте данных с использованием СШВС диалоговое окно Ехрогі бу¬ 
дет выглядеть так, как это показано на рис. 8.5. 





Рис. 8.5. Диалоговое окно Ехрогі. Использование СЮВС 


На следующем шаге, при выполнении экспорта с помощью СШВС, откры¬ 
вается окно СШВС Рогтаіз, содержащее список всех доступных драйверов. 



Рис. 8.6. Окно ОРВС Рогтаіз 


После выбора готового источника или создания нового необходимо вписать 
имя таблицы, в которую будут записаны данные из отчета, в диалоговом ок¬ 
не Епіег СШВС ТаЫе №те, показанном на рис. 8.7. 



Рис. 8.7. Окно Епіег СШВС ТаЫе Ыате 


Далее нажатием кнопки ОК выполняется экспорт данных в указан¬ 
ную таблицу. В случае если указанной таблицы не существует, она будет 
создана, и затем в нее запишутся данные из отчета. Если будет указано имя 
таблицы, которая уже есть в выбранном источнике, появится предупреждение, 
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показанное на рис. 8.8. Данное предупреждение предлагает выбрать другое 
имя для таблицы либо предварительно удалить существующую таблицу. 


X] 


/ ТаЫе аігеасіу ехЫя, Ріеа5е и$е апоЫіег ^аЫе пате, ог уои сап геЬгу а^ег гетоѵіпд іЬе ЬаЫе. 




Рис. 8.8. Предупреждение об экспорте в существующую таблицу 


Примечание 

Для экспорта данных в СЮВС-источник можно использовать только табличную 
форму отчетов. Все другие варианты отчетов будут сохранены некорректно ли¬ 
бо с ошибками. 

Упражнение 8.1 

1. Экспортируйте отчет с подотчетами в М8 \Ѵогб или М$ Ехсеі. 

2. Экспортируйте отчет через СШВС в любую базу данных и посмотрите 
результат. 

8.2. Распространение отчетов 
с помощью Сгузіаі Епіегргізе или 
Сгузіаі Верогі Арріісаііоп Зегѵег 

В большинстве современных компаний стоит задача не только сформиро¬ 
вать огромный набор отчетов, но и быстро доставить эти отчеты до конеч¬ 
ного пользователя. Одним из вариантов решения такой задачи может счи¬ 
таться установка Сгузіаі Кероііз на рабочие места пользователей. Однако это 
повлечет за собой необходимость в обучении пользователей работе с Сгузіаі 
Кероііз. Кроме того, часто рабочие станции у конечных пользователей име¬ 
ют слишком ограниченные возможности для установки Сгузіаі Керогіз, или 
в соответствии с политикой фирмы устанавливать специализированное 
программное обеспечение можно только со специального разрешения сис¬ 
темного администратора и руководства. Для обеспечения быстрой и эко¬ 
номной доставки отчетов до конечного пользователя в Сгузіаі Керогіз вклю¬ 
чены механизмы, позволяющие работать с отчетами, используя \УеЪ- 
технологии и не устанавливая дополнительного программного обеспечения. 

В различных версиях Сгузіаі Керогіз имеются разные компоненты, обеспе¬ 
чивающие доступ к отчетам из Интернет. В Сгузіаі Керогіз 8.0 есть два ком- 
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понента, которые позволяют вызвать отчеты из браузера, такого как Іпіетеі 
Ехріогег или Ыексаре Соттипісаіог: 

□ Сгу$Га1 \ѴеЬ СотропегП Зегѵег 

□ Сгузіаі Ра§е Зегѵег 

Подробно механизмы работы с данными компонентами описаны в книге 
"Введение в Сгу$Га1 Верогй", Маклаков С., Матвеев Д. Интерфейс-Пресс. 
Богородский печатник. 

Начиная с Сгу$Га1 Кероі1$ версии 8.5 и выше, вместо этих компонентов 
появилась самостоятельная специализированная среда распространения и 
администрирования отчетов Сгу$1а1 Епіегрше. Сгузіаі Епіегргізе в отличие от 
Сгузіаі \ѴеЬ Сошропепів предоставляет следующие возможности: 

□ средства быстрого распространения отчетов; 

□ средства администрирования; 

□ средства обработки отчетов по расписанию; 

□ механизмы локализации. 

Так же помимо Сгузіаі Епіегргізе есть возможность распространения отчетов 
с помощью Сгу$1а1 Кероп Арріісапоп Зегѵег (КАЗ). Внешний вид и основная 
функциональность Сгузіаі Кероіт Арріісаііоп Зегѵег такие же, как и у Сгузіаі 
Епіегргізе. 

^ Примечание 

Пробная версия среды распространения отчетов Сгузіаі КероП Арріісаііоп 
Зегѵег поставляется совместно с Сгузіаі Нерогіз 9. 

8.2.1. Архитектура Сгузіаі Епіегргізе 9 

Система Сгузіаі Епіегргізе является многозвенной. Все компоненты этой 
системы предназначены для выполнения различных задач. Причем некото¬ 
рые из компонентов можно устанавливать не только на компьютеры, нахо¬ 
дящиеся под управлением М3 ѴѴіпсіотѵв 9Х, МЕ, №Г или 2000, но и на ма¬ 
шины, управляемые ІЖІХ или Упих. Сгузіаі Епіегргізе имеет четыре 
основных звена (схема 8.1): 

□ клиентское звено 

□ интеллектуальное звено 

□ исполнительное звено 

□ звено данных 

Из схемы видно, что каждое звено Сгузіаі Епіегргізе состоит из нескольких 
компонентов. 
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ѴѴеЬ-сервер / ѴѴеЬ Соппесіог (работает в ѴѴіпсІоѵѵз, ІІНІХ и Упих) 



ОБАР-источники: Реляционные БД: Другие источники: 

ЗАР ВѴѴ, ЗОБ, ООВС, ОБЕ РВ, ХМБ, ЕКР, СКМ, СОМ 

Ноіоз, ЕззЬазе Прямой доступ 



Схема 8.1. Структура звеньев Сгузіаі Епіегргізе 


Состав клиентского звена: 

□ элементы работы через браузер (Іпіегпеі Ехріогег или ІЧеІзсаре Соттипісаіог): 

• еРогЙоІіо — рабочее окно конечного пользователя, которое вызывает¬ 
ся из браузера и не требует установки дополнительного программного 
обеспечения на компьютер пользователя; 

• Сгузіаі Мапа§етепІ Сопзоіе — рабочее место администратора Сгузіаі 
Епіегргізе, которое вызывается удаленно из браузера и не требует ус¬ 
тановки дополнительного программного обеспечения на компьютер 
администратора; 

□ приложения: 

• Сгузіаі СопГщигаІіоп Мапа§ег — утилита администратора для выполне¬ 
ния настройки всех серверных компонентов Сгузіаі Епіегргізе. Может 
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находиться как на машине с Сгузіаі Епіегргізе, так и на машине адми¬ 
нистратора; 

• Сгузіаі РиЫі$Ып§ \Ѵі7агсі — утилита разработчика, позволяющая быстро 
разместить необходимые для работы отчеты на сервере Сгузіаі 
Епіегргізе, выполнив предварительную настройку параметров; 

• Сгузіаі Ітрогі \ѴІ7агб — утилита администратора, позволяющая пере¬ 
нести информацию о пользователях, привилегиях и отчетах из Зеа§аІе 
ІпГо 7.Х и Сгузіаі Епіегргізе более ранних версий; 

• Сгузіаі \ѴеЬ \ѴІ7агё — утилита, позволяющая разработчику настроить 
новый вариант СгузіаІ Епіегргізе. 

Интеллектуальное звено содержит следующие компоненты: 

□ ѴѴеЬ Сотропепі Зегѵег — это мост между \ѴеЬ Соппесіог и остальными 
компонентами Сгузіаі Епіегргізе. Данный компонент Сгузіаі Епіегргізе 
выполняет обработку всех запросов от клиентов и возвращает результаты, 
выступая в роли сервера приложений. 

□ \ѴеЬ Соппесіогз — компоненты, которые организуют связь ѴѴеЬ Сотропепі 
Зегѵег с \ѴеЬ-сервером. В зависимости от используемого ѴѴеЬ-сервера и 
операционной системы можно подключать различные ѴѴеЪ Соппесіог. 

П Аиіошаіесі Ргосезз Зсііесіиіег — служба, обеспечивающая функции управ¬ 
ления базой данных Сгузіаі ЕпІегргі$е: 

• обеспечивает защиту информации от несанкционированного доступа; 

• управляет объектами в Сгузіаі Епіегргізе; 

• управляет всеми остальными компонентами СгузіаІ Епіегргізе. 

□ Рііе Керозііогу Зегѵег — состоит из двух компонентов: 

• Іприі Рііе Керозііогу Зегѵег — управляет всеми отчетами, которые были 
опубликованы администратором или пользователем; 

• Оиіриі Рііе Керозііогу Зегѵег — управляет всеми экземплярами отчетов, 
которые были созданы .ІоЪ Зегѵег. 

□ Еѵепі Зегѵег — управляет событиями, связанными с файлами. При ис¬ 
пользовании некоторых настроек Сгузіаі Епіегргізе можно отслеживать 
изменения, которые происходят в определенных каталогах с указанными 
файлами, и выполнять действия с отчетами, опубликованными в Сгузіаі 
Епіегргізе. 

□ СасНе Зегѵег — управляет процессами кэширования информации, запро¬ 
шенной клиентом через ѴѴеЬ Сотропепі Зегѵег. 

Исполнительное звено включает в себя следующий набор компонентов: 

□ .ІоЬ Зегѵег — выполняет обработку отчетов по расписанию, на основании 
данных, переданных из Аиіотаіесі Ргосезз ЗсЬесіиІег, и формирует требуе¬ 
мые экземпляры отчетов, содержащие запрошенные данные; 
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□ Ра§е Зегѵег — выполняет обработку запросов к отчетам и отвечает за ге¬ 
нерацию страниц в формате Епсархиіаіеб Ра§е РогпШ. Страницы данного 
формата содержат информацию о том, как необходимо отображать отчет 
у клиента, Ра§е Зегѵег получает данные непосредственно из базы данных 
или из последнего экземпляра отчета; 

□ Кероіі Арріісаііоп Зегѵег — выполняет функции, сходные с Ра§е Зегѵег. 
Данный компонент, как уже было сказано ранее, входит в комплект по¬ 
ставки Сгу$1а1 Веропз. 

Звено данных организует доступ к множеству различных источников дан¬ 
ных. Сгузіаі КероПз и Сгузіаі Епіегргіхе позволяют использовать большинст¬ 
во современных баз данных в качестве источника данных для отчетов. 

8.2.2. Основы администрирования 
Сгузіаі Епіегргізе 

Для того чтобы организовать корректную доставку отчетов конечному поль¬ 
зователю и обеспечить безопасность работы в сети, необходимо наличие 
средств администрирования и публикации. В Сгуйаі Епіегргізе есть большой 
набор компонентов для администрирования. К таким компонентам относят¬ 
ся следующие приложения: 

□ СгуЫаІ СопГщигаііоп Мапа§ег; 

□ Сгузіаі Мапа§ешепГ Сопзоіе; 

□ Сгузіаі РиЫІ8Іііп§ ѴѴігагб; 

□ Сгузіаі \ѴеЬ ѴѴіхагсІ. 

Сгузіаі СопП§игаІіоп Мапа§ег является приложением, которое ставится на 
компьютер с установленными основными компонентами Сгу&аі Епіегргізе или 
на компьютер администратора. С помощью данной утилиты администратор 
может выполнять различные задачи по управлению и настройке служб, вхо¬ 
дящих в состав Сгузіаі Епіегргізе. Программа Сгузіаі СопГщигаІіоп Мапа§ег 
вызывается с помощью команды меню Зіагі | Рго§гаш8 | Сгузіаі Епіегргізе 9 | 
Сгузіаі СопП§ига(іоп Мапа§ег. При этом появляется окно, показанное на 
рис. 8.9. 

В окне на рисунке изображен список серверных компонентов Сгу$1а1 Епіег- 
ргізе, т. е. компонентов, без которых Сгузіаі Епіегргізе работать не будет. 
Данное окно полностью совпадает по своим свойствам и возможностям 
с окном МісгозоГі Мапа§етепІ Сопзоіе (ММС). Используя приложение Сгухіаі 
Мапа§етепІ Сопзоіе, администратор может выполнить следующие действия: 

□ завершить работу или запустить любой компонент из списка; 

□ изменить параметры работы у любого из компонентов, представленных 
в списке; 
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□ переопределить источник данных, используемый для хранения информа¬ 
ции о Сгувіаі Епіегргіве. 


Сгу*ІаІ СопПдигаЫоп Мападег 


\ г ‘ ''‘ -Х' Ь 


Шш: . *!■ 


Сотриіег Матѳ: ] 


8) Оу$іаІ СасЬе Зегѵег 
8) СгузіаІ Еѵет Зегѵег 
8) СгузізІ Іприі РНе Веро$ііогу 5е... 
§) Сгузіаі Оиіриі Рііе Верозііогу... 
§) Сгузіаі Раде Зегѵег 
8) Сгузіаі Верогг Арріісаііоп Зегѵег 
8) СгузіаІ Верогі *1оЬ Зегѵег 
8) Сгузіаі Ѵ/еЬ Сотрспет Зегѵег 
8) Ѵ/огІсі Ѵ/гсіе Ѵ/еЬ РиЫі$Ьіпд 3... 


Уегеіоп : 

9.0.0.2В1 
9.0.0.2В1 
9.0.0.2В1 
9.0.0.261 
9.0.0.261 
9.0.0.281 
9.2.1.14В 
9.аа2ві 
9.0.0.2В7 
5.0.2195.2966 


| Резсгірііоп _ . 

Ргоѵісіез $сЬесіиІіпд, зесигііу, апсі $у$іет тападетепі $ег\ 
5іоге$ герогі рѳде$ ІгедиепІІу гечиезіесі Ьу герогі ѵіе^ег$. 
Мопііог$ еѵепІ$ 

Ргоѵігіез оЬіесІ зіогаде апсі тападетепі $егѵісе$, 

Ргоѵісіез оЬ]есі зіогаде апсі тападетепі $егѵісе$. 
СепегаІе$ герогі раде$ гедиезіесі Ьу іерогі ѵіеѵѵегз. 

Ргоѵі$егѵісе$ Гог ЬиІІсііпд апсі сшіотігіпд герогіз. 

Иапсііее оГМоасіесі ргосе$$іпд оі герогіз. 

Ргоѵісіе$ а еіпдіе ассе$$ роіпі Гоі аІІ ѵѵеЬ-Ьа$есі геяие$і$ іс 
Ргоѵкіе$ Ѵ/еЬ соппесііѵііу апсі асігліпі$ІіаІіоп іЬгоидЬ іЬе Іі 


Рис. 8.9. Окно СгузіаІ СопГідигаІіоп Мападег 


Основные действия, которые можно выполнять в окне Сгуйаі СопГщигаііоп 
Мапа§ег. 

□ завершить работу любого из компонентов Сгу$1а1 Епіегргізе, для этого не¬ 
обходимо установить фокус на компонент в списке и нажать кнопку [■] 
либо выполнить команду контекстного меню 81ор; 

□ запустить неработающий компонент Сгузіаі Епіегргізе, для этого надо ус¬ 
тановить фокус на требуемый компонент в списке и нажать кнопку 
либо выполнить команду контекстного меню 8іагі; 

□ перезапустить компонент Сгузіаі Епіегргізе или компонент, представлен¬ 
ный в списке, для этого необходимо установить фокус на компонент 
в списке и нажать кнопку либо выполнить команду контекстного ме¬ 
ню Кеяіагі. 

Большинство компонентов, представленных в окне Сгузіаі СопГщигаііоп 
Мапа§ег, имеют идентичный набор параметров. Для их просмотра и изме¬ 
нения необходимо завершить работу интересующего компонента и, нажав 
кнопку [Щ либо вызвав контекстное меню, выполнить команду Ргорегйез. 
При этом появится диалоговое окно свойств выбранного компонента. Один 
из возможных вариантов показан на рис. 8.10. 
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В ряде случаев возможны некоторые отличия. Однако дополнительные 
параметры в диалоговом окне свойств или являются нередактируемыми, или же 
их настройку лучше выполнять с помощью Сгузіаі Мапа^етеШ: Сопзоіе. 




Ргорегій» | Оерепгіепсу ) Соппесііоп | Сопііділайоп | 


Зегѵег Туре:. 


Оі«р1ау Ыагое: 

|0у$№АР5 • . 

Бегѵег Мате: 

|ОЕМ$-СМРар* 

Сотспапі . 

'; I'’ЧЧОЕNІ8*СМР\с1$;\Ргодгат |мІе$\Сіу$ІаІ Ье • 

ЗіагІирТуре: 

. ^Аиіотаііс ^ 



Р $у«іѳтАссоипі 

Оіег 

|іо-;а$усіегп * ' | 

Ра$$ѵчон± ; . 

;у:Д:Й? 

рэпіігт ра»ѵѵогі:. .Дѵ; ; .. 


:.У; 

ОК | СапсеІ. | Арріу - | Неір 


Рис. 8.10. Окно настройки параметров для СгуБІаІ АРЗ. Аналогичные окна 
отображаются для других компонентов Сгуэіаі Епіегргізе 


Независимо от того, настройка какого компонента выполняется, диалоговое 

окно свойств содержит следующие вкладки: 

□ Ргорегііез — основные свойства выбранного компонента Сгузіаі 
Епіегргізе; 

□ Берепйепсу — список приложений, от которых зависит корректная работа 
выбранного компонента Сгузіаі Епіегргізе; 

□ Соппесііоп — список ІР-адресов, которым разрешен доступ к компонен¬ 
там и отчетам Сгузіаі Епіегргізе; 

□ СопЯ§игаііоп — параметры конфигурации, для некоторых компонентов 
они могут иметь ряд отличительных особенностей. 

На вкладке Ргорегііез могут быть заданы следующие параметры: 

□ Зегѵег Туре — тип сервера; 

□ Бізріау Иаше — имя, отображаемое при просмотре списка компонентов; 

□ Зегѵег Иаше — физическое имя сервера; 

□ Соттапб — команда, с помощью которой выполняется запуск сервера; 
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□ Зіаііир Туре — тип запуска, принимающий значения из списка: 

• Ашотаііс — запуск сервера производится в момент загрузки операци¬ 
онной системы; 

• ОізаЫесі — сервер недоступен; 

• Мапиаі — сервер запускается вручную; 

□ 1ю§оп А$ с возможными значениями: 

• Зузіет Ассоипі — в случае, когда данный параметр активен, загрузка 
сервера производится независимо от того, кто запустил компьютер, 
иначе используются параметры, описанные ниже; 

• ІАег — имя пользователя в домене или на локальном компьютере; 

• Ра55\ѵопі — пароль пользователя; 

• СопПгт Ракхѵѵогсі — подтверждение пароля пользователя. 

Кроме описанных вкладок в диалоговом окне настройки свойств, для Сгузіаі 
Яероіі Арріісаііоп Зегѵег и Сгухіаі КероЛ ІоЬ Зегѵег, имеется еще вкладка 
Рагате(ег8, которая позволяет определить некоторые специфические пара¬ 
метры для указанных служб. 

Сгузіаі Епіегргізе допускает хранение информации о пользователях, приви¬ 
легиях и отчетах в различных типах источников данных. При установке 
Сгу$іа1 Емегргізе обычно в качестве хранилища используется МЗОЕ или М3 
ЗС^Ь Зегѵег, если его компоненты установлены заранее. Однако во многих 
случаях по различным соображениям использование МЗОЕ или М3 30)Ь 
Зегѵег недопустимо. Для таких случаев предусмотрена возможность переноса 
хранилища в другой вариант источника данных. Допустимые источники 
данных показаны в диалоговом окне Зеіесі БаіаЬаке Бгіѵег на рис. 8.11. 


шаош *і 

СЬоо$е а ссппесйоп теіЬосі: 

& ООВС 

Г* Огасіе паііѵе скіѵег 
^ 0В2 паііѵе <±іѵег 
• С $уЬа$е пайѵе сігіѵег 


ОК 


Сапсе) 


Рис. 8.11. Диалоговое окно Зеіесі ОаіаЬазе Огіѵег. Выбор источника данных 
для хранилища СгузіаІ Еліегргізе 


Для того чтобы сменить источник данных, используемый в качестве храни¬ 
лища, и перенести имеющуюся информацию, необходимо выполнить сле¬ 
дующие шаги: 

1. Завершить работу компонента Сгузіаі АРЗ (см. разд. 8.2.2). 


8 Зак. 1021 






ок 
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Рис. 8.12. Диалоговое окно СгузіаІ АРЗ РгореПіез. 
Вкладка Сопіідигаііоп 
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Рис. 8.13. Окно АРЗ ОаІаЬазе Зеіир 
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2. Вызвать диалоговое окно Сгуяіаі АР8 Ргорегііея и перейти на вкладку 

Соп1і§ига1іоп (рис. 8.12). 

3. На вкладке Сопб§ига(іоп нажать кнопку 8ресііу, после чего откроется диалого¬ 
вое окно АР8 ЦаіаЬазе 8е1ир, см. рис. 8.13. Тот же результат будет получен 

в случае, если вместо вызова окна Сгукіаі АР8 Ргорегйез нажать кнопку ІЛ_ . 

4. В окне АР8 І)аІаЬаке 8еІир необходимо выбрать один из вариантов кон¬ 
фигурирования источника данных и нажать кнопку ОК. Список возмож¬ 
ных действий выглядит так: 

• Зеіесі а Наіа Зоигсе — выбор нового источника данных для хранилища 
Сгузіаі ЕпГегргізе. 

• Сору баГа (гот апоГйег Баіа Зоигсе — копирование информации в но¬ 
вое хранилище из использовавшегося ранее. 

• Кесгеаіе Ше сиггепі ОаГа Зоигсе — создание пустого хранилища в те¬ 
кущем источнике. 

5. В случае выбора опции Зеіесі а БаШ Зоигсе появится диалоговое окно, 
показанное на рис. 8.11. В этом окне необходимо выбрать желаемый ва¬ 
риант источника и, если потребуется, указать его параметры (рис. 8.14): 

• имя сервера базы данных; 

• имя пользователя; 

• пароль пользователя. 



І-одг>Ю: 


1 - 

Раяѵгай. 


ОК } СапсеІ | 


Рис. 8.14. Окно определений параметров подключения 
к выбранной базе данных 


6. Если параметры определены корректно, то будет выполнено переключе¬ 
ние на новый источник. Для того чтобы не возникало сообщений об 
ошибке, необходимо в окне Сгукіаі АР8 Ргорегііез на вкладке СопІі§ига1іоп 
(рис. 8.12) сделать активным параметр СЬап§е СІияіег №те Іо и вписать в 
поле имя компьютера, на котором установлен Сгузіаі Епіегргізе. 
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7. Когда производится подключение к новому источнику данных, нужно 
выполнить перенос информации о пользователях, привилегиях и отчетах 
из ранее использовавшегося хранилища. Для этого необходимо выпол¬ 
нить действия п. 2 и п. 3. В окне АР8 І)а1аЬазе 8е1ир выбрать параметр 

Сору <Ыа ігот апоіЬег Баіа 8оигсе и нажать кнопку ОК. 

8. В диалоговом окне 8ресііу Баіа 8оигсе, показанном на рис. 8.15 из вы¬ 
падающего списка 8оигсе сопіаіпз йаіа ігот ѵегзіоп выбрать один из ва¬ 
риантов: 

• Аиіосіеіесі — автоматическое определение типа источника; 

• Сгузіаі Епіегргізе 8.0; 

• Сгузіаі Епіегргізе 8.5; 

• Сгузіаі Епіегргізе 9.0. 



Рис. 8.15. Окно Зресііу Раіа Зоигсе. Выбор источников 
для синхронизации данных 

9. Далее, нажав кнопку Зресііу, находящуюся напротив поля Оеі Баіа ігот, 
выбрать источник, из которого необходимо перенести данные. Механизм 
выбора совпадает последовательностью действий, описанной в п. 5. 

10. В поле Сору Іо (Ііе ГоІІо\ѵіп§ гіаіа зоигсе также можно указать источник, 
куда требуется перенести информацию. 

11. При нажатии кнопки ОК будет произведено копирование данных между 
выбранными источниками. 

Если новый источник данных позволяет выполнять подключение к нему, 
используя учетную запись операционной системы, то можно, не изменяя 
ничего более, запустить Сгузіаі АР5. При корректном выполнении операций 
по переключению на новый источник данных Сгузіаі АР8 запустится, после 
чего можно будет приступать к работе с Сгузіаі Епіегргізе. Если новое хра¬ 
нилище Сгузіаі Епіегргізе требует подключения через учетную запись зареги- 
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стрированного в хранилище пользователя, необходимо перед запуском 
Сгухіаі АРЗ выполнить три действия. 

1. С помощью административных утилит операционной системы зарегистри¬ 
ровать пользователя, имя которого и пароль совпадают с именем и паролем 
пользователя, являющегося владельцем хранилища Сгуйаі ЕШегрше. 

2. Вызвать диалоговое окно Сгуйаі АР8 Ргорегііез и на вкладке Ргорегііез 
в разделе Ьо§ Оп А* сделать неактивным параметр Зузіет Ассоипі, 
а в поля Шег, Ра§5ѵѵоп1 и Сопйгт РаззіѵогсІ вписать имя созданного на 
первом шаге пользователя или выбрать его из списка, его пароль, под¬ 
тверждение пароля. 

3. Далее можно запустить Сгухіаі АРЗ, предварительно закрыв окно Сгузіаі 
АР8 Ргорегйез. 

Для удаленного администрирования компонентов Сгуйаі Епіегрпзе можно 
воспользоваться приложением, которое использует ѴѴеЬ-технологии и не 
требует установки дополнительных программ. Данное приложение требует 
наличия на компьютере только браузера (Іпіегпеі Ехріогег или Ыексаре 
Сопшшпісасог) и возможности выхода в сеть. Запуск административного 
элемента Сіухіаі Епіегргіхе осуществляется выполнением команды меню 
8іаг1 | Рго§гаш8 | Сгузіаі Епіегргіяе 9 | Сгувіаі ЕаипсЬрай При выполнении 
этой команды появляется окно браузера с открытой стартовой страницей 
Сгузіаі Еійегргіяе так, как это показано на рис. 8.16, 
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Рис. 8.16. Окно Сгузіаі ЬаипсНраЦ 
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Гпава 8 


На этой странице необходимо выбрать ссылку Сгузіаі Мапа§етепі Сопзоіе. 
При выполнении перехода по этой ссылке откроется страница Сгузіаі 
Мапа§етеп( Сопзоіе Ьо§ Оп, показанная на рис. 8.17. 


| '3 ОуаГаІ МападегоепЕ Сипьоіе - МісгосоЙ: 


|І РіЬ ЙЛ Ѵіеѵѵ Раѵогііез ТооЬ Нф 

]: : ^» Вйс?ѵ ;г «?■ _ ѵ - ^ і.-^5ѳагсЬ Г >.) ВаѵогіЬе5 ^Н&іогу ^ Ш ^ 

] Ад(І№55|^Ьнр://ІІег^5-стр/сгу5иі/ег^егргі5е9/а^ггип/еп/ас1тіп.слт 


СгувіаІ Мападетепі Сопзоіе 




-^<дО | ■ Мпк 5 >у 


Кедіаіег 1 АЬоиІ | Н&Ір 


Сгузіаі Мападетепі Сопзоіе 1_од Оп 


Епіег уоиг и$ег пате апгі равхѵѵоиі. ТНеп сііск і_од Оп. 

(іГуои аге ип$иге оГуоиг зссоит тГогтаноп, сотаауоиг $у5іет 
асітіпізігэйг.) 
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Рис. 8.17. Страница Сгузіаі Мападетепі Сопзоіе Ьод Оп 


На этой странице необходимо выбрать параметры подключения к Сгузіаі 
Епіегргізе. 

□ АиіЬепІісаііоп Туре — способ авторизации: 

• ЬОАР (Іл§Ы\ѵеі§1іі Оігесіогу Ассезз Ргоіосоі). 

• Епіегргізе — только для зарегистрированных пользователей Сгузіаі 
Епіегргізе. 

• \Ѵіпбо\ѵз ЫТ — для пользователей, которые имеют право использовать 
учетные записи операционной системы. 

□ Шег Мате — имя пользователя Сгузіаі Епіегргізе, при установке Сгузіаі 
Епіегргізе создается пользователь Абшіпізігаіог. 

□ Раззѵѵогй — пароль пользователя Сгузіаі Епіегргізе (пользователь 
Абтіпізігаіог по умолчанию не имеет пароля). 
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После ввода параметров подключения и нажатия кнопки Ьо§ Оп открывает¬ 
ся рабочая страница СгузіаІ Мапартепі Сопзоіе, показанная на рис. 8.18. 



Рис. 8.18. Сгузіаі Мападетепі Сопзоіе. Основная рабочая страница 


Ссылки на данной странице можно определить следующим образом: 

□ Мапар Шегз — раздел, используемый для просмотра и администрирова¬ 
ния пользователей; 

□ Мапар Сгоирз — раздел, используемый для просмотра и администриро¬ 
вания групп пользователей; 

□ Мапар ОЩесіз — раздел, используемый для просмотра и публикации 
отчетов; 

□ Мапар Роіёегз — раздел, используемый для просмотра, редактирования 
и создания папок; 

□ Мапар Еѵепіз — раздел, используемый для настройки событий, которые 
относятся к обработке отчетов; 

□ Мапар Зегѵегз — раздел, используемый для администрирования компо¬ 
нентов Сгузіаі Епіегргізе по аналогии с Сгузіаі СопГщигаІіоп Мапарг; 
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П Мапа§е 8егѵег Сгоирз — раздел, используемый для просмотра и админи¬ 
стрирования групп серверов Сгу&аі Епіегргізе, которые могут работать 
под управлением различных операционных систем в единой сети; 

□ Манате 8ейіп§$ — раздел, позволяющий настроить основные параметры 
работы Сгувіаі Епіегргізе; 

□ Мапа§е АиШогі/аІіоп — раздел, содержащий информацию о лицензии и 
доступных способах авторизации. 

Перейдя по ссылке Мапа§е ІІзегз, администратор имеет возможность: 

□ просмотреть список уже зарегистрированных пользователей; 

□ зарегистрировать нового пользователя (если разрешает лицензия); 

□ изменить список привилегий, если это необходимо. 
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Рис. 8.19. СгузіаІ Мападетепі Сопзоіе. Страница со списком 
зарегистрированных пользователей 


Для того чтобы зарегистрировать нового пользователя, необходимо нажать 
кнопку №\ѵ ІІзег. При этом откроется страница №\ѵ 11§ег, показанная 
на рис. 8.20. Заполнив поля в этой странице и установив соответствующие 
параметры, можно нажать кнопку ОК для сохранения информации. 
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Рис. 8.20. СгувіаІ Мападетепі Сопгоіе. Регистрация нового пользователя 


Обязательными к заполнению полями являются: 

□ Ассоипі N 8016 — имя пользователя; 

□ Ра88\ѵогй — пароль пользователя; 

□ СопПгш — подтверждение пароля. 

Также возможна установка дополнительных параметров: 

□ Соппесііоп Туре — тип пользовательского соединения: 

• Сопсиггепі ІІвег — конкурентный пользователь; 

• Ыагпеё ІІзег — именованный пользователь; 

□ Ра85\ѵогй пеѵег ехрігез — действие пароля никогда не истекает; 

□ Мзег ішізі сЬап§е развѵопі аі пехі 1о§оп — пользователь должен изменить 
пароль при следующей регистрации; 

□ ІІзег саппоі сЬап§е ра$з\ѵогсі — пользователь не имеет права изменять пароль. 

После выполнения регистрации нового пользователя или при редактирова¬ 
нии прав существующего пользователя можно перейти в раздел МешЬег оГ 
(рис. 8.21). 
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Г пава 8 
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Рис. 8.21. Сгузіаі Мападетепі Сопзоіе. Ассоциация пользователя с группой 
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Рис. 8.22. Сгузіаі Мападетепі Сопзоіе. Страница Сгоирз 
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Рис. 8.23. СгузіаІ Мападетепі Сопзоіе. Страница Мет Сгоир 
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Рис. 8.24. Сгузіаі Мападетепі Сопзоіе. Страница АсІтіпізІгаТогз раздел ІІзегз 
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Глава 8 


Один пользователь может быть ассоциирован с одной или несколькими 
группами. Соответственно, такой пользователь будет обладать всеми теми 
привилегиями, которые определены у групп. 

Для просмотра, редактирования и создания новых групп необходимо перей¬ 
ти на страницу Мапа§е Сгоирз, которая показана на рис. 8.22. 

Чтобы создать новую группу пользователей, требуется нажать кнопку Ыеѵѵ 
Сгоир. При этом откроется страница Сгоир, показанная на рис. 8.23. 

После того как в поля Сгоир №те и Безсгірйоп введена требуемая инфор¬ 
мация, можно нажать кнопку ОК и перейти к странице ЕІзегз, содержащей 
список ассоциированных с группой пользователей. 

Нажав кнопку Ай<1 Цзегз, можно ассоциировать новых пользователей 
с группой, выбрав их из списка. Если перейти на страницу 8иЬ§гоир, то 
можно будет добавить подгруппы, которые так же, как пользователи, выби¬ 
раются из списка. На странице МешЬег оГ можно выполнить обратный про¬ 
цесс. То есть определить текущую группу как подгруппу в другой группе. 

С помощью Сгузіаі Мапа§етепІ Сопзоіе администратор имеет право быстро 
выполнять публикацию и настройку отчетов, действуя удаленно. Для этого 
необходимо перейти на страницу Оіуесіз, которая показана на рис. 8.25. 
На этой странице представлен список уже опубликованных отчетов с указа¬ 
нием папки, в которой они находятся, и с их описанием. 
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Рис. 8 . 25 . Сгузіаі Мападетепі Сопзоіе. Страница ОЬіесІз 





























Распространение отчетов 


231 



I Цсгу^дІ Мооарсго«* Сопюіе МкгосоКІліегпсІ Еиріикг 



I |"и«рСГ*ІКѴ I 


|ітр5402е<ЬсОс5Ь7П 

Ггз /ЛприУа_111 -001 /С0(М67/6а4 геіЪсОйЬЫЗО .рі 



иь?-.“оіат » 

25 С5.200Э 17 23 30 
25 06 200317.23 Эб 



Р 5п<мѵгеро(ШитЬпаіі 
Г ЕпаЫв гврозіІагугаіѴваГі 


1 ЧрОвіе і! К»»П 


Рис. 8.27. Сгувіаі Мападетепі Сопзоіе. Страница с элементами настройки 

опубликованного отчета 
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Гпава 8 


Для публикации нового отчета необходимо нажать кнопку №ѵѵ Керогі и пе¬ 
рейти на страницу №\ѵ Керогі (рис. 8.26). 

Нажав кнопку Вго\ѵзе с помощью стандартных механизмов операционной 
системы можно выбрать отчет, который требуется опубликовать. Далее ука¬ 
зывается папка, в которой отчет должен быть сохранен. Папка может быть 
выбрана в группе полей, находящихся под комментарием ІЪеп зеіесі 
а йезііпаііоп Гоігіег іп ѵѵЬісЬ іо заѵе іКе герогі. После того как отчет будет со¬ 
хранен в указанной папке, внешний вид страницы с отчетом изменится так, 
как представлено на рис. 8.27. 

На данной странице имеются следующие вкладки: 

□ Ргорегііез — основные параметры опубликованного отчета. Его систем¬ 
ное имя, каталог, в который он записан, описание и т. п.; 

□ Ніяіогу — история работы с отчетом, если существует настройка его об¬ 
работки по расписанию; 

□ Аіегі ІЧоііПсаііоп — список сообщений, включенных в отчет; 

□ ИаіаЬазе — параметры подключения отчета к базе данных; 

□ Рагашеіегз — список параметров, включенных в отчет; 

□ Ріііегя — список условий фильтрации данных, включенных в запрос, 
формирующий набор данных для отчета; 

□ ЗсЬесіиІе — параметры обработки отчета по расписанию; 

□ Бекііпаііоп — способ доставки отчета, полученного в результате его обра¬ 
ботки по расписанию, до конечного пользователя; 

□ Рогтаі — формат, в котором доставляется отчет до конечного пользова¬ 
теля; 

□ Ргіпі 8еіир — настройки принтера для обработки отчета по расписанию, 
если назначена печать отчета; 

□ ІЛПЙІ8 — ограничения, накладываемые на хранимые экземпляры отчета; 

□ Кі§Ьі8 —• права, предоставленные различным группам на работу с опуб¬ 
ликованным отчетом: 

• N 0 Ассе$$ — нет доступа; 

• Ѵіе\ѵ — только просмотр; 

• ЗсЬесіиІе — только установка параметров расписания; 

• Ѵіе\ѵ Оп Оегпапё — просмотр по требованию; 

• Риіі Сопігоі — полный доступ; 

• Аёѵапсеб — развитые возможности работы с отчетом; 

□ Ргосе§§ — параметры, указывающие, на каком сервере и как необходимо 
выполнять данный отчет. 
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Выполнив все шаги настройки отчета, администратор может гарантировать 
корректную их работу и быструю доставку до конечного пользователя в тре¬ 
буемом виде. 

Как видно из перечисленного, все отчеты хранятся в папках. Для создания 
папки необходимо перейти на страницу Роійеге и, нажав кнопку №\ѵ Роійег, 
перейти в окно №\ѵ Роійег, показанное на рис. 8.28. 
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Рис. 8 . 28 . Сгузіаі Мападетепі Сопзоіе. Страница Ыеѵѵ Роійег 


Определив имя папки и ее описание, можно сохранить данную папку в хра¬ 
нилище Сгухіаі Епіегргі$е. После сохранения папки станут доступными 
вкладки: 

□ Керогіз — список отчетов, которые опубликованы в данной папке. При 
необходимости можно добавить отчет, выбрав его из списка уже опубли¬ 
кованных отчетов; 

□ 8иЬГо1(1ег5 — список подкаталогов; 

□ Ілтк$ — ограничения, наложенные на хранящиеся экземпляры отчета; 

□ Кі§Ь{$ — привилегии на работу с отчетом, предоставленные различным 
группам пользователей. 
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Гпава 8 


К основным элементам администрирования относятся возможности по уда¬ 
ленному управлению и настройке компонентов самого Сгузіаі Епіегргізе. 
Для того чтобы перейти к настройке данных компонентов, необходимо вы¬ 
звать страницу Мапа§е Зегѵегя. 
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Рис. 8.29. Сгувіаі Мападетепі Сопзоіе, Страница управления 
серверами СгузіаІ Епіегргізе 


Как видно из рисунка, список компонентов, представленных на данной 
странице, полностью совпадает со списком компонентов, входящих в Сгу$іа1 
Мапа§етепі Сопзоіе. Для того чтобы выполнить настройку необходимого 
компонента, требуется перейти по соответствующей ссылке на страницу ре¬ 
дактирования параметров и произвести желаемые изменения. Необходимо 
помнить о том, что страничка 8егѵег§ автоматически не обновляется. Так 
как после каждого изменения параметров выбранного компонента этот 
компонент перезапускается, для получения сведений о нормальной работе 
компонента потребуется перезагрузить страницу Зегѵегз. 

Все остальные элементы администрирования относятся либо к информа¬ 
ции только для чтения, либо позволяют выполнить настройки, связанные 
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с ограничениями, накладываемыми на отчеты или на пользователей. Все эти 
ограничения можно наложить и с помощью описанных ранее компонентов 
Сгу$1а1 Мапа§етепІ Сопвоіе. 

Очень часто возникает необходимость распространять отчеты не по одному, 
а целыми группами, выбирая их из каталога на компьютере. Такую функ¬ 
циональность предоставляет утилита Сгувіаі РиЫі$Ып§ ѴѴіхагб. Вызов этого 
приложения можно выполнить с помощью команды меню 8іагі | Рго^гатя | 
Сгузіаі Епіегргіве 9 | Сгузіаі РиЫівЬт§ \Ѵігагй. Появится окно, которое пока¬ 
зано на рис. 8.30. 



ѴѴеІсоте іо Ніе СгузіаІ РиЫізНіпд 
ѴѴІ2ЭГСІ 


ТНі$ ѵѵігагсі ИеІр$ уои асісі Сгу$іаІ Нероги Іоуоиг Оу$ІаІ 
Епіегргйе $у$1ет. Чл/ііИ іИі$ ѵѵігагсіуои сап: 

♦ Асісі героги Іо іНе $у$ 1 ет 

♦ 5 еІ гіеіаиіі іодоп апсі рагатеіег іЫогтаІіоп 

♦ 5 сИесіиІе герог» ирсіаіез 

ТЫоидНоиі іЬі$ ѵѵігагсі, уои тау ргосеесі іо іЬе пехі раде Ьу 
сііскіпд Нехі, ог геѵіаіі а ргеѵіоих раде Ьу сііскіпд Васк 

То Ьедіп риЫі$Ніпд уош герогі, сііск N6X1. 


X] 


'у Сапсеі - ' - Неір 


Рис. 8.30. Диалоговое окно СгузіаІ РиЫізИіпд ѴѴігагсІ 


Утилита построена по принципу многостраничного диалога. При нажатии 
кнопки N6x1 производится переход на следующую страницу. Следующей 
страницей, которая открывается за той, что изображена на рис. 8.30, являет¬ 
ся страница, позволяющая выбрать один или несколько отчетов для публи¬ 
кации. 

В этом окне есть такие элементы: 

□ Агігі Миіііріе Керогів — параметр, разрешающий одновременную публи¬ 
кацию нескольких отчетов; 

□ Ріпгі Бігесіогу — поиск каталога, содержащего отчеты для публикации, 
кнопка доступна только при активном параметре Агігі Миіііріе Керогів; 

□ Ріпй Рііе — поиск файла отчета для публикации; 
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□ А<М Бігесіогу — добавление файлов отчетов из указанного каталога 
в список разрешенных к публикации, кнопка доступна только при ак¬ 
тивном параметре А«1й Микіріе Керогіх; 

□ Іпсіийе 8иЬГоІ<іег§ — параметр, позволяющий добавить информацию 
из подкаталогов, доступен только при активном параметре Агігі Микіріе 
Керогіз; 

□ 8е1ес( АН — выбор всех отчетов для публикации, кнопка доступна только 
при активном параметре А<М Микіріе Керогіз; 

□ Оезеіесі АН — отмена выбора всех отчетов для публикации, кнопка дос¬ 
тупна только при активном параметре Агігі Микіріе Керогіз 


г СгуііаІ РиЫіДнпу Ѵ/ігагс) 


ШШ?'\ -іі 


5 еІесІ А Рііе 

СНоо$е а героП Іо риЫізК Ѵои тау риЫІ$Н тиіііріе герогіз аі опсе Ьу сЬескіпд 
іНе "Асід тиНірІе герогіз" Ьох. 



Рііе ог Оігесіогу: )0:\Сгу$івІ В 00К. 9.0ЧГ лавы книгіАЗатрІез 

Р Агігі тиіііріе герогіз Ріпсі Оігесіогу !. . РіпсіРіІе 


Асісі Гііез іо іИе ІІзІ Ьох Ьеіоѵѵ еііЬег ілсііѵісіиаііу ог Ьу $ресі!уілд [Не сіігесіогу. Зеіесі Іке 
сИескЬохез а&зосіаіесі ѵѵііЬ іЬе герогіз уои ѵѵоиИ Ііке іо риЫізН, іНеп сІІск Иехі 


Асісі Оігесіогу 


Р ІпсЫе $иЫокіег$ 


Зеіесі АН 


Оезеіесі АН 


Мате 


ІпРігесІогу 


0Ш 501_Врі#1.грі СІІ О:\СгузіаІВ0ОКЭ.О'чГлѳвыкииги\$аг 


±1 


< Васк 


МехІ> 


СапсеІ 


Неір 


Рис. 8.31. Диалоговое окно СгугІаІ РиЫізЫпд ѴѴІгаггі. 

Выбор публикуемых отчетов 


Следующим шагом после выбора отчетов для публикации будет регистрация 
на сервере Сгу$1а1 Епіегргізе. На данном этапе поддерживаются те же меха¬ 
низмы, что и в Сгу$іа1 Мапа§ешепІ Соп§о1е. После регистрации в Сгуйаі 
Епіегргізе появляется возможность выбора папки, в которую будут запи¬ 
саны выбранные отчеты, если требуемой папки не существует, ее можно 
создать. 

Далее можно будет убедиться в том, что выбранные отчеты будут записаны 
в указанную папку. После того как администратор убедился в правильности 
указанного пути сохранения отчетов, он может перейти к установке пара¬ 
метров обработки отчетов по расписанию (рис. 8.33). 
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В\ Сгу5каІ РиЫізЫпд Ѵ/іглгсІ 


АР5 Роігіег 

5ресІ(у іЬе АР5 (оісіег іп ѵчИісН уои ѵѵоиісі ІІке уоиг герогі(§) іо арреѳг. 


штктт? *і 

■ 




ЗеІесНЬе ?оісіег іо «ЫсЬуои ѵѵоиМ Ііке Іо аскіуоиг герогІ($]. Ѵои тау асЙ а пею 
(оісіег шіпд іЬе Иеѵм Роігіег Ьиііоп Іо іКе гідЫ о? ІНе Гоісіег ігее. 

■' >3 


гі <^} 0ЕШ5-СМР 
В- С] М5ас 
Е-СІ1 ВероіІ 5атрІе$ 
гі О У«ег Роісіег® 

В СЙ Асіипігв аігаюг 
ІЗЗ ]»!??$ 
Й-і*) Зией 

а ІЙ и5Ево 


< баск |~ 


ЫехО 


СапсеІ 


Неір 


Рис. 8.32. Выбор папки, для сохранения отчетов 


I* Оувіаі РиЫі5Ьісчд ѴѴігаггі 


5сНесіиІе Іпіегѵаі 

Зеі Иоѵѵ о(»еп іИе оЬ|есІ і$ ирсіаіесі. Ѵои тау $еІ іЬе $ате гесиггепсе (ог 
тиіііріе оЬІесІз аі опсе (Ноісі сіоѵѵп іИе СігІ кеу ѵѵИІІе $еіесйпд оЬ|есІ$). 


х] 




С Випопсеопіу 

(* 1_еІ и$ег$ иргіаіе ІЬе оЬіесі 

С Яип оп а гесиггіпд $сНесіиІе 


< Васк | N ехі > \ СапсеІ [ Неір 

Рис, 8.33. Выбор принципа публикации отчета 
и его обработки по расписанию 

В этом окне можно выбрать один из трех вариантов публикации отчета: 

□ Кип опсе опіу — запустить отчет один раз на обработку сразу после пуб¬ 
ликации. 
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□ Ье* и$ег§ иргіаіе 1Ье оіуесі — предоставить пользователю возможность 
задать параметры обработки самостоятельно. 

□ Кип оп а гесиггіп" зсЬейиІе — установить параметры обработки по графи¬ 
ку заранее. 

Следующий шаг — выбор способа публикации. 


В* Сгуііаі РиЫііНіпд ЧѴігагіІ 


Ш§ 


СКапде ІМаиИ Ѵаіиех 

СЬоо$е ѵѵке»Иег ог по» уои ѵѵізЬ »о сИапде гіеГаиН $е»»іпд$. 



ТНе ѵѵігагсі Ьаз поѵѵ соііесгесі аіі »Ье іпіогтаііоп і» пееск »о риЫі$Ь уоиг герог»$ Іо »И© 
Сгу$*аІЕп»егргі$е$у$»ет. 

Нсѵѵеѵег,уои тау ѵѵі$И Іо тос% $рвсі/іс герогі ргорег»іе$ Ье&эге риЫі$Ыпд (е.д. ііЯе, 
сіа»эЬа$е Іодоп іпіоітаііоп, рагагбеіеі ѵаіиео). 

II уои сНоо$е по» »о сНапде »Ы$ ІпІогтаЬ'оп. ІИе ѵѵігагсі ѵѵіИ.и$е ехізйпд іпіогтаііоп Іп 
»Ке Сгу$*аІ Перог» ПІе »о $е» »Не$е герог» рюрегііез. 

С РиЬЬЬ герог»$ ѵѵі»Иои» тосіііуіпд ргорег»іе$ 

& Веѵіеѵѵ оі гооСЙу герог» ргдрег йё 4 


< Васк 


Нех»> 


Сапсеі 


Неір 


Рис. 8.34. Выбор варианта публикации 


Есть два варианта: 

□ РиЫізІі герогіз \ѵііЬои( тогііГуіп^ ргорегііев — публикация отчетов без из¬ 
менения их свойств. 

□ Кегіе» ог тогііГу герог* ргорегііех — просмотреть или изменить свойства 
отчетов. 

В случае, когда выбран второй вариант публикации отчетов, появится воз¬ 
можность изменить наименование отчета, сделать его описание, определить 
параметры подключения к базе данных, задать значения параметров, вклю¬ 
ченных в отчет, и т. п. 

Если выбран не один отчет, а несколько, надо будет определить параметры 
всех отчетов в списке. После того как заданы все параметры для выбранных 
отчетов, можно выполнять операцию их публикации. В случае, если в мо¬ 
мент публикации не произошло никаких ошибок, будет получено сообще¬ 
ние, показанное на рис. 8.35. 
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Рис. 8.35. Окно завершения публикации отчета или группы отчетов 


Таким образом, используя данную утилиту, администратор Сгуйаі Епіегргізе 
имеет возможность быстро предоставить конечным пользователям доступ 
к большому количеству новых отчетов, заранее определив ряд необходимых 
параметров. 

Утилиты Сгузіаі Ітрогі ѴѴігагсі и Сгузіаі \ѴеЬ ѴѴігагё используются крайне 
редко и имеют следующую функциональность: 

□ Сгузіаі Ітрогі \ѴігапІ ~ позволяет выполнять импорт данных из более 
ранних версий Сгузіаі Епіегргізе. Механизм импорта данных полностью 
совпадает с тем подходом, который используется при переключении на 
другой источник данных в качестве хранилища Сгузіаі Епіегргізе; 

□ Сгузіаі \ѴеЪ \Ѵігаг<І — позволяет создать немного другой внешний вид для 
рабочего места пользователя. Изменения, которые можно получить с по¬ 
мощью данной утилиты, относятся к цветовому оформлению, внешнему 
виду некоторых рабочих страниц еРогДоііо и допустимым вариантам под¬ 
ключения к Сгузіаі Епіегргізе. В большинстве случаев такие изменения 
быстрее выполняются на уже существующих страницах. 

8.2.3. Рабочее место конечного 
пользователя — еРогНоІіо 

Для того чтобы конечный пользователь имел возможность работать с отче¬ 
тами, необходимо наличие всего лишь браузера (Іпіегпеі Ехріогег или 
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№і$саре Сотшипісаіог). Вызвать рабочее окно пользователя еРоПіоІіо мож¬ 
но одним из следующих способов: 

□ в браузере набрать команду следующего вида: 

• 1шр://<Имя \ѴеЬ-сервера>/сгу$іа1/егиегргі$е9/еРогіГо1іо, 

□ если на компьютер конечного пользователя устанавливалась клиентская 
часть Сгузіаі Епіегргізе, то обратиться к рабочему окну можно с помощью 
выполнения команды меню 8*аг( | Рго§гаіш | Сгузіаі Епіегргіхе 9 | Сгукіаі 
Еаипсйрагі и в появившемся окне выбрать ссылку еРогіТоІіо. 

И в том и в другом случае появится страница, показанная на рис. 8.36, 
предлагающая, как и в случае работы с Сгуйаі Мапа§етепі Сопхоіе, выбрать 
способ авторизации на сервере Сгузіаі Ешегрше и указать имя и пароль. 



После того как все параметры заданы и нажата кнопка Оп, появляется 
страница, которая строго индивидуальна для каждого пользователя. На этой 
странице указано имя зарегистрированного пользователя, представлен спи¬ 
сок отчетов, с которыми пользователь может работать, и есть ряд элементов, 
позволяющих выполнять персональные настройки еРогіГоІіо и организовы¬ 
вать поиск требуемых отчетов по различным условиям. 
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ГЦсРогЫЫіо - МісюявП: ІоЬегпек Ехріогег 


| Рііе Еск Ѵіе*» Раѵогйм Тоок Н«ір 

• 4- баск * ^ /3 • фЗеагсК [%|РаѵогИе$ гГ^Нійогу ; 4^ У# « С*} О 


; Ао<±-ви К'р://<1еги5'стр/сг>йаІ/еп{егргі5е9/еРог^оІю/еп/аѵАІаЫе.С5р > радеѴіе'«*5иЬ5Сіірсіоп 


(ѵ*бо Пііпк$ * 


ф *» іі Ш (і 



Рис. 8.37. Рабочее окно зарегистрированного пользователя СгувіаІ Епіегргізе 
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1 і&бо ' І-Іпкі * 
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IЬИе т|ш 5еагсЬ I 
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5оПВу:|ТіЯе 



?тр54О?8іІ)',Сі;ііР 7 0 
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Іп$1эпсез О 


Рис. 8.38. Контекстное меню для отчета в еРогМоІіо 
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Для работы с отчетами есть контекстное меню, которое появляется при 
одинарном щелчке левой клавишей мыши на иконке отчета в рабочем окне 
(рис. 8.38). 

Вызываемое меню имеет как минимум три команды: 

□ Ѵіетѵ — просмотр отчета в заранее заданном формате. 

□ 8сЬесІиІе — установка параметров расписания для обработки отчета. 

□ НізСогу — история по экземплярам отчета. 

При вызове команды Ѵіеи' на экране появляется новое окно браузера, в ко¬ 
тором отображается либо отчет, либо предлагается ввести параметры под¬ 
ключения к базе данных и задать различные параметры, если они нужны. 
Отчет, отображенный в браузере, показан на рис. 8.39. 


'Э Сгу»1а! Керогі* Ѵіеижг - міігоіоЛ ІиЬегпсІ ЬцЖігег 
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НОМЕР ЗА ДАТА ЗАКАЗ КОЛИН 

ЕС-ТВ0 Т ОРГАНИЭА11ИЯ 

имя продавца 

НАИМЕНОВАНИЕ 

ЦЕНА ТО 


100 000,00 01.01 2002 0 00 00 

5,00 Организация к*і 

ивзи 

Табурет 

250,00 


100 000,00 01.01 2002 0.00 00 

1,00 Организация N«1 

Иван 

Стол 

966.00 


100000,00 01.01.2002 0.00 00 

1,00 Организация №1 

Иван 

Горка 

1 150,00 


100 007.00 10 01.2002 0 0000 

1,00 Организация №2 

Петр 

Компьютерный стол 

12 523.00 


100 007,00 10 01.2002 0 ОО'ОО 

1,00 Организация №2 

Петр 

Диван угловой 

15647,00 


Ю0 007.00 1001.2002 000:00 

2.00 Организация N82 

Петр 

Кресло мягкое 

4 645.00 


100 014.00 23 01 2002 0 00.00 

100,00 Организация N83 

Алексей 

Лампа накаливания 

15,00 


100014.00 23 01.2002 0.00.00 

100.00 Организация N83 

Алексей 

Лампа дневного света 

99,00 


100 021,00 24 01 2002 0 0000 

1,00 Организациями 

Алексей 

Рапазопіс 5Ц205 

4 205.00 


100 021.00 24,01.2002 0.0000 

1,00 Организация №4 

Алексей 

Квпѵѵоой К209 

10 982.00 


100 021,00 24 01 2002 0 00 00 

1,00 Организация N84 

Алексеи 

Ѳгацл КЮОО 

5 194,00 


100 021.00 24 01.2002 0.00:00 

1,00 Организация N84 

і 

Алексей 

І.0ѴѴ1955 

7 250,00 







д 


Рис. 8.39. Отчет, просматриваемый с помощью ѴѴеЬ-технологий 


Как видно из рисунка, в отчет попадает не только необходимая для работы 
информация, но и включаются элементы навигации, позволяющие облег¬ 
чить работу клиента с большим объемом данных. 

На рис. 8.40 представлен вариант страницы, которая будет показана в случае 
необходимости определения параметров подключения к базе данных. 
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Подобного рода страница будет сформирована в случае наличия в отчете 
параметров и других, динамически задаваемых условий. 


| ''З Сгу«Л аі КершЬ Ѵіеиег - МкгобоП ІпЬегпеЕ Ехріогег 




1| ^ Васк - - 'Э ІІ1 йЭ | ^5мгсЬ' ЗіРаѵоЛ!5 0Нкйгу ф 



ОаІаЬазе Ьодоп 



А 

Рис. 8.40. Страница ввода параметров соединения с базой данных, 
используемой в отчете 

Если вызвать команду ЗсЬеёиІе, то на экране появится дополнительное окно 
браузера, в котором будет отображена страница настройки параметров обра¬ 
ботки отчета по расписанию (рис. 8.41). 

Как видно из рисунка, существуют разные варианты запуска отчета по времени: 

□ Мкт — запустить отчет непосредственно сейчас; 

□ Опсе — запустить отчет один раз в указанное время; 

□ Ноигіу — запускать отчет через каждые N часов; 

□ Баііу — запускать отчет через каждые N дней; 

□ \Ѵеек1у — запускать отчет в указанный день недели; 

□ МопІМу — запускать отчет каждый ІЧ-ый месяц в году; 

□ ІЧІН Бау оГ МопІЬ — запускать отчет в указанный день каждого месяца; 

□ 1 51 Мопёау оГ МопІЬ — запускать отчет в первый понедельник каждого 
месяца; 
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□ Ьа$1 Бау оГ МопЙі — запускать отчет в последний день каждого месяца; 

□ X Бау оГ Ші \Ѵеек оГ йіе МопЙі — запускать отчет в указанный день ука¬ 


занной недели каждого месяца. 


Оічеі для книги N 21 

Сизіотіге уоиг орііопз: | ЗсЪесІиІе 


5е1 ІНе гип-ііте рзгзтеіегз Тог Ш$ героя: 

Рип герои N0^ 

РерогіѵѵіІІ ш Опсе 
Ноигіу 
йаііу 
ѵѵеекіу 
МопСЫу 

ІЧСЪ йэу о? МопСЬ 
І5С Мопсіау оі МопСЬ 
Іа5С Эау оі МопсЬ 
х Рау о( №Ъ ѵѵеек огсЪе Моп 


Рис. 8.41. Страница ЗсИейиІе. Выбор времени запуска отчета 


Оічегдпя книги №1 

Сіізіотіге уоиг орііопз (зсЬегіиІе 


ОаСаЬазе Юдоп еіБіе гип-ііте рагзтеіегз Гог Шз героя: 

РіІСегз 

“ оп ^ - 

Ргіпс ВеКіпдз . 

--керогі ѵѵііі шп поѵѵ. 


Рис. 8.42. Страница ЗсЬегіиІе. Выбор других настроек 
для выполнения отчета по расписанию 
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Помимо временных параметров существует набор других параметров, кото¬ 
рые МОЖНО установить ДЛЯ корректной обработки отчета. Список возмож¬ 
ных настроек представлен на рис. 8.42. 

К возможным настройкам относятся: 

□ ЗсНеёиІе — настройка параметров времени запуска, описанная ранее; 

□ БаІаЬазе Ео§оп — настройка параметров доступа отчета к базе данных; 

□ Рагашеіегз — установка значений параметров, используемых в отчете; 

□ РіІІегз — настройка параметров фильтрации данных, поступающих в от¬ 
чет из источника; 

□ Бекііпаііоп — настройка параметров сохранения результата обработки 
отчета: 

• ПеГаиІІ — сохранение в каталог, который определен при настройке 
Сгузіаі Етегрше; 

• ІІшпапа^её Бйік — сохранение в каталог, который может находиться 
на любом доступном диске; 

• Етаіі (8МТР) — отправка отчета по почте с использованием протоко¬ 
ла 8МТР; 

• РТР — размещение отчета на РТР-сайте; 

□ Рогтаі — формат, в котором необходимо получить результат от обработ¬ 
ки отчета: 

• Сгузіаі Керогі — стандартный формат отчета; 

• Ехсеі — экспорт отчета в формат Ехсеі; 

• Ехсеі (Баіа Опіу) — экспорт в Ехсеі только данных; 

• \Ѵоггі — экспорт отчета в формат М5 \Ѵогб; 

• АсгоЪаІ — экспорт отчета в формат РОЕ; 

• ИсЬ Техі — экспорт отчета в формат К.ТР; 

• Ріаіп Техі — экспорт отчета в текстовом формате; 

• Ра^іиаіей Техі — экспорт отчета в текстовый формат с разбивкой на 
страницы; 

• ТаЬ-зерагаІей Ѵаіиез — экспорт отчета в текстовый формат с раздели¬ 
телями табуляцией; 

• СНагасІег-верагаІей Ѵа1ие$ — экспорт отчета в текстовый формат с вы¬ 
бранными символьными разделителями; 

□ Ргіпі Зеіііпр — настройка параметров печати отчета после его обработки. 

После установки параметров обработки отчета по расписанию и нажатия 
кнопки 8сЬе<іи1е появляется окно Нікіогу (рис. 8.43). 
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3 еРогіГоІсо - Нюіогу - МісюыіВ: Мете* Емріогег 


'■'к-; -Г* . •- ' ' 


-ІПІ XI 


НІ5ІОІУ 










ІЙ <>: -;.уѴ д 

>ей-ѳ$Н I Сапсй ^ неір 


Огчег дпи книги й»і 


▼ !пя<к$се Тііио: Ким Ьу: 

С> ( 20.‘200 3 ‘ 2.3 ■*. .02 ЛМ 2>нр« 


Рагатеіегз: 


1 Реіеіе {| Райхе |ГКе$ите )| СІеаг ДІІ ІГ5еІес* АІІ } 
Яоггші: 5Ших: Зеіесіесі; 

і «г Репсітп Г - 




Рис. 8.43. Окно НізГгогу. Момент ожидания обработки отчета 


Точно такое же окно Ніяіогу можно вызвать для любого доступного отчета, 
выполнив команду НЫогу. Единственным отличием такого окна в данном 
случае будет статус отчета: 

□ отчет не имеет истории. Окно пустое; 

□ отчет содержит список, состоящий из информации о выполнении отчета 
по расписанию: 

• Репс1іп§ — отчет ожидает выполнения; 

• Киппіп§ — отчет обрабатывается; 

• Зиссезз — отчет обработан корректно; 

• РаІ$е — отчет обработан с ошибками. 

В случае если отчет был обработан без ошибок, его можно открыть для про¬ 
смотра. Если отчет обработан с ошибками, то информацию об ошибках 
можно узнать по ссылке Раіве. Кроме того, после обработки отчета по рас¬ 
писанию в контекстном меню появляется дополнительная команда Ѵіе^ѵ 
ЬаГевГ Іпкіапсе (рис. 8.44). 

При наличии большого количества опубликованных и доступных для рабо¬ 
ты отчетов иногда желательно выполнить поиск. В окне еРогйГоІіо имеется 
механизм поиска отчетов по различным параметрам. Для того чтобы найти 
отчет, необходимо в поле Ьоок Рог ввести требуемое условие поиска, 
в выпадающем списке выбрать критерии поиска и нажать кнопку 8еагсЬ. 
Если существует отчет, который удовлетворяет заданным критериям, он бу¬ 
дет выведен на экран в виде соответствующей иконки. 














Распространение отчетов 


247 



Рис. 8.44. Основное рабочее окно еРогНоІіо. Контекстное меню отчета, 
обработанного по расписанию 

Критерии поиска могут быть следующими: 

□ ТШе — поиск по заголовку отчета; 

□ Оечсгірііоп — поиск по описанию отчета; 

□ Гоіёег Ш1е — поиск по наименованию папки; 

□ аіі Пеіёз — поиск по всем возможным вариантам. 

Помимо элементов работы с отчетами и средств поиска в еРогіГоІіо есть ряд 

кнопок, при нажатии которых можно получить доступ к дополнительным 

возможностям: 

□ РиЫіс/РаѵогіІех — данная кнопка при нажатии меняет свой статус. По¬ 
зволяет быстро переходить от общедоступных отчетов к наиболее часто 
используемым; 

□ Ог§апІ 2 е — помогает организовать структуру папок и отчетов, хранимых 
в этих папках; 
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□ РгеГегепсев — предоставляет возможность настроить персональные пара¬ 
метры рабочего места еРогЙбНо; 

□ Ьо§оГГ — выход из еРогіГоІіо; 

□ Неір — вызов подсказки. 

При нажатии кнопки Ог§апіге открывается страница Ог§апіхе Роігіегв, пока¬ 
занная на рис. 8.45. 


3 еРогНоІіо - Огдапіге Раѵогііев - іеговой: ІпЬепмй: 


~3 



Огдапіге РоИегз 









ьЧ: ; " '. 

СІ 056 | Неір 


Сопіепіз: огдапіге (Ііеге Гоісіегз агкі ііетз. 


)ОЕІМІ5 СМР@0ЕМІ5-СМР ' 3 Ёі[ СИ 

__ 

ДКероіТ Загпріез 
ДШег РоЫегз 


Оопе 


_ 2І 

! . і § іосаПпЬгапек ^ 


Рис. 8.45. Настройка параметров папок СгувіаІ Епіегргіее 


В данном окне есть следующая функциональность: 

□ Ехрапгі — раскрыть содержимое папки; 

□ Сору То — скопировать папку или отчет в указанное место; 

□ Моѵе То — переместить папку или отчет в указанное место; 

□ 81юі1:сиІ — организовать ссылку на отчет; 

□ Кепаше — переименовать папку или отчет; 

□ Беіеіе — удалить папку или отчет. 

При нажатии кнопки РгеГегепсев открывается страница ІІ$ег РгеГегепсев, 
на которой можно определить основные характеристики рабочего места 
клиента. 

Возможности по настройке рабочего места таковы. 

□ ІпШаІ Ѵіе\ѵ — набор установок, позволяющий определить папку, показы¬ 
ваемую в момент запуска еРогШНо. 
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Рис. 8.46. Окно 1)вег Ргеіегепсев 


□ Тор-Іеѵеі ГоИег Ьаг — параметр, который позволяет скрыть или показать 
верхнюю панель кнопок в рабочих окнах. 

□ Оп ту ёе$кіор $Ьо\ѵ те — в рабочем окне показывать отчеты в следующем 
виде: 

• ТІштЪпаіІ ѵіе\ѵ. 8еі іЬе питЬег оГ герогів (тах.) рег ра§е — отчеты со 
снимками (если есть снимки). Выбирается количество отчетов на 
страницу. 

• ЬІ8І ѵіе\ѵ. 8еі іЬе пшпЪег оГ герог(8 (тах.) рег ра§е — отчеты должны 
быть представлены в виде списка. Выбирается количество отчетов на 
страницу. 

• Асііоп ѵіе\ѵ. 8еі Йіе питЬег оГ герог(8 (тах.) рег ра§е — отчеты должны 
быть представлены в виде списка со ссылками на допустимые дейст¬ 
вия. Выбирается количество отчетов на страницу. 

□ Бікріау ту герогіз; 

• іп а 8Іп§1е Ьгоѵѵвег ѵѵіпгіоѵ, опе герогі аі а ііте — одно окно для про¬ 
смотра отчетов. Можно увидеть только один отчет; 
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• іп тиіііріе Ъптвег \ѵіпёо\ѵ8, опе \ѵіп(іоѵѵ Гог еасЬ герогі — каждый отчет 
открывается в своем окне. 

□ Рог еасЬ герой вЪоѵ те — определяет, что показывать: 

• Ое§сгірііоп — описание; 

• Оѵѵпег — владельца; 

• Баіе — дату публикации; 

• ИшіпЬпаіІ (іГ аррНсаЫе) — снимок, если существует; 

• іпяіапсе соипі — количество готовых экземпляров. 

□ 8Ь<от тепи а§ — определяет, в каком виде показывать меню: 

• Ъиііоп8 лѵіііі іехі — кнопки с текстом; 

• Ъиііоп8 опіу — только кнопки; 

• іехі опіу — только текст. 

□ І)І8рІау ту (іевкіор \ѵіі1і іЬІ8 соіог 8сЬете — отображать рабочее окно с ис¬ 
пользованием цветовой схемы, представленной в таблице, 

□ Ѵіе\ѵ ту герогів и8іп§ іЬе... — просматривать отчеты с использованием 
одной из следующих технологий: 

• АсііѵеХ — в качестве окна просмотра используется компонент АсііѵеХ, 
требуется установка компонента на компьютер клиента; 

• БНТМЬ — в формате НТМЬ-страницы; 

• Іпіегасііѵе БНТМЬ — просмотр отчета в формате НТМЬ с рамками 
(Ргате); 

• іаѵа — просмотр отчета с помощью .Іаѵа Арріеі, требуется установка 
компонента на компьютер клиента; 

• Даѵа Р1и§-Іп — просмотр отчета выполняется с помощью компонента 
Іаѵа Р1и§-Іп, требуется установка компонента на компьютер клиента; 

• 1Чаѵі{>аіог Р1и§-Іп — просмотр отчета выполняется с помощью компо¬ 
нента, аналогичного по своим характеристикам АсііѵеХ, требуется ус¬ 
тановка компонента на компьютер клиента. 

□ РгеГеггей теа8игіп§ ипіі8 Гог герогі ра§е Іауоиі І8... — предпочитаемые еди¬ 
ницы измерения. 

□ Му сиггепі ііте-гопе І8... — текущая временная зона. Используется для 
обработки отчетов по расписанию. 

Различные механизмы просмотра отчетов в браузере позволяют подобрать 
тот вариант, который наиболее подходит к отчетам определенного вида. 
Единственным недостатком такого подхода является то, что на компьютер 
клиента необходимо установить АсііѵеХ, .Іаѵа, .Іаѵа Р1и§-Іп или №ѵі§аіог 
Р1и§-Іп. Не во всех компаниях клиент имеет право устанавливать какое-либо 
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I 3 СгуйлІ Яерцті» Ѵіемег - МіствзеК (піетмі Ехріогѵг 
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Рис. 8.49. Отчет в формате Іпіегасііѵе 0НТМ1_ 



Рис. 8.50. Отчет в формате Заѵа 
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Рис. 8.51. Отчет в формате Ыаѵідаіог РІид-Іп 


программное обеспечение без ведома администратора. Для того чтобы изба¬ 
виться от необходимости установки перечисленных ранее компонентов, же¬ 
лательно пользоваться любым из вариантов ЭНТМЬ. Этот механизм про¬ 
смотра отчетов не потребует установки дополнительных компонентов. 

Внешний вид отчетов, просматриваемых с помощью различных технологий, 
представлен на рис. 8.47—8.51. К сожалению, вариант просмотра отчетов 
с помощью .Іаѵа Р1и§-Іп работает не во всех версиях браузеров, поэтому ри¬ 
сунка, соответствующего данному варианту, нет. 

Таким образом, используя предложенную функциональность, пользователи 
быстро и качественно смогут настроить свое рабочее место и получать отче¬ 
ты в том виде, который необходим для работы. 

8.2.4. Локализация рабочего места 
конечного пользователя — еРогііоНо 

Стандартная поставка Сгухіаі Епіегргізе предполагает использование англий¬ 
ского языка в наименованиях компонентов рабочего окна пользователя. Од¬ 
нако очень часто перед компаниями, внедряющими Сгузіаі Епіегргізе у себя 
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или на заказ, встает задача выполнить локализацию рабочих страниц еРогі- 
Гоііо. Учитывая то, что все основные рабочие страницы сформированы как 
СЗР-страницы (СгузШІ Зегѵег Ра§ез) — аналогом АЗР (Асііѵе Зегѵег Ра§ез), 
для людей, знакомых с АЗР-технологией, не составит труда выполнить кор¬ 
ректировку исходных текстов и получить требуемый результат. Кроме того, 
следует знать, что все СЗР-страницы содержат специализированные разде¬ 
лы, предназначенные для локализации. 


^ Примечание 

Следует помнить, что все файлы СЗР при редактировании необходимо сохра¬ 
нять в кодировке ІІТР8. Это связано с тем, что для работы с хранилищем и вы¬ 
вода информации в многоязыковом формате, такая кодировка подходит боль¬ 
ше всего. Хотя в Сгузіаі Епіегргізе 8.0 и Сгузіаі Епіегргізе 8.5 существовал ряд 
проблеме этой кодировкой. 


Все рабочие страницы Сгузіаі Епіегргізе находятся в каталоге С:\Рго§гат 
РіІез\СгузІа1 Оесізіопз\\ѴеЪ Сопіепі\Епіегргізе9\еРогіГо1іо\еп\. С помощью 
обыкновенного текстового редактора можно открыть все файлы, находя¬ 
щиеся в указанном каталоге, и изменить значения соответствующих пере¬ 
менных. Различия между двумя файлами показаны в листингах 8.1 и 8.2. 




Лйстинг 8.і;| Часть файла аѵаіІаЫе.сзр до редактирования раздела, 
относящегося к локализации 




Рііе Ѵегзіоп ЗСагР - Бо поС гетоѵе Ыііз іі уои аге тойііуіпд 
Ыіе іііе 

Виіісі: 9.0.0 
Рііе Ѵегзіоп ЕпЦ 


<Ылі1> 

<Пеас1> 

<%@ 1апдиаде=ЦаѵаЗсгірІ: сойераде=65001%> 

<% 

// аѵаіІаЫе.сзр 
// 

// ТПіз іііе із гезропзіЫе іог Ыіе таіп раде оі СЬе аррІісаСіоп. 
// ІС Йізріауз Ыіе ІізС оі іоійегз апсі Ыіе ІізС оі оЬзесСз 
// іп Йіе сиггепС іоійег. ІС Ьапйіез ЬЬе риЫіс апй 
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// іаѵогіЬез ѵіеи, апй зеагсЪіпд 


/ / 5ЕКѴЕК-ЗЮЕ 5ТКІШ ѴАКІАВЬЕЗ РОК ЬОСАЫЙІШ 
//********************************************************************* 
ѵаг Ь_МЕЬСОМЕ_1 = "АссоипЬ: 

ѵаг Ь_КЕРОКТ_ТІТЪЕ_ЗЕАКСНРАКАМЕТЕК = "ЬіЫе"; 
ѵаг Ь_КЕРОКТ_ОЕЗСКІРТІОН_ЗЕАКСНРАКАМЕТЕК = МезсгірСіоп"; 
ѵаг Ь_5ЦВСАТЕООКУ_ТІТЬЕ_ЗЕАКСНРАКАМЕТЕК = "іоіаег ЬіЫе"; 
ѵаг Ь_АЬЬ_РІЕЬ03_ЗЕАКСНРАКАМЕТЕК = “аіі ііеіаз”; 
ѵаг Ь_НОМЕ = " Ноте " ; 

ѵаг Ь_Н0МЕ_ЗШЗСКІРТІ0Ы_РАТН = "РаѵогіЬез 

ѵаг Ь_ЗЕАКСН_КЕЗЦЬТЗ_РАТН = "ЗеагсЬ НезиІЬз: 

ѵаг Ь_РЦВЫС = "РиЫіс” ; 

ѵаг Ь_МуяеР 0КТЗ = "РаѵогіЬез”; 

ѵаг Ь_ЗІСШР = "Зідп Ыр” ; 

ѵаг Ь_ЬОСОРР = "ЬодоЬЬ”; 

ѵаг Ь_ЬОСОК = ”Ьод Оп"; 

ѵаг Ь_ѴІЕИМАЫАСЕК = "Огдапіге"; 

ѵаг Ь_ЕХІТ = “ЕхіЬ"; 

ѵаг Ь_ЗЕТТІШЗ = "Ргеіегепсез" ; 

ѵаг Ь_НЕЬР = "Неір"; 

ѵаг Ь_ТУРЕ = "Туре:"; 

ѵаг Ь_АЬЬ = "АН"; 

ѵаг Ь_КЕРОКТ = "КерогЬ"; 

ѵаг Ь_АМАЬУТІСАЬ_КЕРОКТ = "АпаІуЬісаІ КерогЬ"; 


Шистин^8-2 


2!:ШЖ 


Рііе Ѵегзіоп ЗЬагЬ - Бо поЬ гетоѵе ЬЪіз іі уои аге тоаііуіпд 
Ьііе Ьііе 

Виііа: 9.0.0 
Рііе Ѵегзіоп Епа 


<ЬЬт1> 

<Ъеаа> 
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<%@ ІапдиадеЫаѵаЗсгірЬ со<3ераде=65001%> 

<% 

// аѵаіІаЫе.сзр 
II 

// ТЪіз іііе із гезропзіЫе іог Ыіе шаіп раде оі Йіе аррІісаЫоп. іь 
дізріауз Йіе ІізЬ 

// оС іоідегз ап<3 Йіе ІізЬ оі. оЬз'есРз іп Йіе сиггепЬ іоідег. ІЬ ІіапсЗІез 
Йіе риЫіс апй 

II іаѵогіЬез ѵіеад, апд зеагсЪіпд. 

И 

//********************************************************************* 
//8ЕКѴЕК-ЗГОЕ ЗТКІШ ѴАКІАВЬЕЗ РОК ЬОСАЬІЕІШ 
//********************************************************************* 
ѵаг Ь_ИЕЬС0МЕ_1 = "Учетная запись: 

ѵаг Ь_КЕР0КТ_ТІТЬЕ_5ЕАКСНРАКАМЕТЕК = "заголовок отчета"; 
ѵаг Ь_КЕР0КТ_0Е5СКІРТІ0Н_ЗЕАКСНРАКАМЕТЕК = "описание отчета"; 
ѵаг Ь_8ЦВСАТЕС0КУ_ТІТЬЕ_5ЕАКСНРАКАМЕТЕК = "наименование папки"; 
ѵаг Ь_АЬЬ_РІЕЬОЗ_ЗЕАКСНРАКАМЕТЕК = "все поля"; 
ѵаг Ь_НОМЕ = "Ноте ”; 

ѵаг Ь_Н0МЕ_8ЦВ5СКІРТІ0Н_РАТН = "РаѵогіСез"; 

ѵаг Ь_8ЕАКСН_КЕ5ШЛ'5_РАТН = "ЗеагсЬ КезиІЬз: 

ѵаг Ь_РЦВЫС = "РиЫіс"; 

ѵаг Ь_МУКЕР0КТ5 = "РаѵогіЬез"; 

ѵаг Ь_ЗІСШР = "Зідп ГГр"; 

ѵаг Ь_ЬОООРР = "Ьодоіі" ; 

ѵаг Ь_ЬОСОН = 11 Ьод Оп “ ; 

ѵаг Ь_ѴІЕММАМАСЕК = "Огдапіге"; 

ѵаг Ь_ЕХІТ = "ЕхіЙ'; 

ѵаг Ь_ЗЕТТІШЗ = "Ргеіегепсез"; 

ѵаг Ь_НЕЬР = "Неір"; 

ѵаг Ь_ТУРЕ = "Туре:"; 

ѵаг Ь_АЬЬ = "А11"; 

ѵаг Ь_КЕРОКТ = “КерогС"; 

ѵаг Ь_АНАЬУТІСАЬ_КЕРОКТ = "АпаІуЫсаІ Керогй'; 

Результат обработки первого листинга показан на рис. 8.52. 
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Результат обработки второго листинга показан на рис. 8.53. 

Таким образом, используя самый обыкновенный текстовый редактор, любой 
человек может выполнить локализацию всей рабочей области еРогіГоІіо 
в сжатые сроки. 

^ Примечание ^ 

В случае если не все элементы изменяются при редактировании файлов СВР, 
необходимо обратиться к ѴѴеЬ-разработчикам для уточнения места, где можно 
исправить наименование объекта, выводимое на экран. 

Помимо описанных возможностей работы в Сгухіаі Епіеіргізе, есть также ме¬ 
ханизмы внесения дополнительной функциональности. Для того чтобы уз¬ 
нать, каким образом выполняется программирование и внесение своих собст¬ 
венных функций, необходимо обратиться к разделу документации Сгу&іаі 
Епіеіргіхе 80К, которая поставляется совместно с пакетом Сгуйаі Епіегргізе. 

Примечание 

Следует помнить, что вся основная и дополнительная функциональность 
должна быть реализована с помощью языка ЗаѵаЗсгірі. Это делается для под¬ 
держки многоплатформенности. 



Глава 9 



Интеграция отчетов, созданных 
с помощью Сгузіаі Верогіз, 
в приложения 

9.1. Возможности интеграции 

Как видно из содержания предыдущих глав, Сгузіаі Кероііз 9 является мощ¬ 
ным и удобным генератором отчетов, а Сгузіаі Епіегргізе предоставляет сред¬ 
ства доставки отчетов пользователям. Однако очень часто возникает необхо¬ 
димость доставлять отчеты конечным пользователям не с помощью \ѴеЪ- 
технологий, а интегрировать имеющийся набор отчетов в приложения. Учи¬ 
тывая эту необходимость, компания Сгузіаі Оесізіопз (5еа§аіе Зойѵ/аге) пред¬ 
лагает несколько механизмов, позволяющих вызывать созданные с помощью 
Сгузіаі Керогіз 9 отчеты из приложений, устанавливаемых у пользователей. 
В зависимости от квалификации разработчиков и времени, отведенного на 
разработку, можно выбирать из следующих возможностей: 

□ Сгузіаі Керогі Еп§іпе АРІ — наиболее развитый, но и наиболее трудоем¬ 
кий механизм; 

□ Сгузіаі Керогі АсііѵеХ Сопігоі — самый простой и быстрый способ инте¬ 
грации отчетов, но поддерживается не вся функциональность, доступная 

в Сгузіаі Керогі Еіщіпе АРІ; 

□ Сгузіаі Керогі Сотропепі для Беірііі — компонент, созданный на основе 
функций Сгузіаі Керогіз АРІ, поддерживаются различные версии ОеІрЬі; 

□ Сгузіаі Керогі КОС (Керогі Безі^пег Сотропепі) — компонент, позво¬ 
ляющий не только выполнять интеграцию существующих отчетов, но и 
создавать новые отчеты в момент работы приложения, требует дополни¬ 
тельного лицензирования. 

Каждый из представленных механизмов обладает своими достоинствами и 
недостатками. Поэтому для того чтобы иметь возможность сравнить пред¬ 
лагаемые способы, рассмотрим несколько примеров интеграции отчетов 
в приложения. В качестве средств разработки будем использовать Вогіапсі 
ОеІрЬі 6.0 и Місгозой Ѵізиаі Вазіс 6.0, а в качестве механизмов интеграции 
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рассмотрим Сгузіаі Керогі АРІ, Сгузіаі Керогі АсІіѵеХ Сопігоі и Сгузіаі 
Керогі Сотропепі. 

Примечание ^ 

Описание возможности интеграции отчетов Сгузіаі Керогіз 9 в приложения 
можно найти в разделе документации Сгузіаі Оеѵеіорегз Неір, поставляемой 
совместно с Сгузіаі Керойз 9. И хотя все примеры в документации и в этой кни¬ 
ге ориентированы на использование Ѵізиаі Вазіс и ОеірИі, можно также вос¬ 
пользоваться любыми средствами разработки, которые допускают использова¬ 
ние АРІ либо АсІіѵеХ. 


9.2. Использование Сгузіаі Рерогі Епдіпе АРІ 

Для того чтобы получить доступ к функциям Сгузіаі Рерогі Еп§іпе АРІ, 
необходимо каким-то образом подключить соответствующую библиотеку 
к разрабатываемому приложению. Библиотекой, которая содержит функции 
Сгузіаі Рерогі Епдіпе, является файл сгре32.сІ11. Этот файл устанавливается 
совместно с Сгузіаі Рерогіз 9, и найти его можно в каталоге С:\Рго§гат 
Рі1ез\Соттоп Рі1ез\Сіузіа1 Оесізіопз\2.0\Ьіп, если операционная система ус¬ 
тановлена на диске С. В этом же каталоге находятся все основные файлы, 
необходимые для работы компонентов Сгузіаі Рерогіз 9. При интеграции 
отчетов в приложения многие из этих файлов должны входить в конечный 
пакет, устанавливаемый у пользователя. При разработке приложений с по¬ 
мощью Оеірііі или Ѵізиаі Вазіс, для подключения библиотеки можно вос¬ 
пользоваться специально созданными файлами-модулями, в противном слу¬ 
чае следует применять механизмы работы с функциями АРІ. 

^ Примечание 

Многие из приведенных далее примеров содержат функции и типы, список ко¬ 
торых приведен в Приложении 1 и Приложении 2. 


9.2.1. Вызов отчетов Сгузіаі Рерогіз из приложений. 
Использование функций Сгузіаі Рерогіз АРІ 

При разработке приложения с помощью Оеірііі необходимо обеспечить воз¬ 
можность вызова функций Сгузіаі Керогі АРІ. В простейшем случае можно вос¬ 
пользоваться информацией, изложенной в Приложении /ив Приложении 2, и 
описать самостоятельно прототипы требуемых функций, однако для ускорения 
этого процесса можно воспользоваться уже готовым файлом СКОеІрйі.раз, со¬ 
держащим описание всех функций и типов. Данный файл находится на 
диске с дистрибутивом Сгузіаі Керогіз 9 в каталоге \\Тоо1з\Оеѵе1орегз. 
В том же самом каталоге находится архив с примерами. Для того чтобы 
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использовать данный файл, его удобно скопировать в каталог, где будет со¬ 
хранен проект приложения. 

^ Примечание 

Файл СРЮеІрРі.раз и примеры доступны только в дистрибутивах Сгузіаі 
РероПз 9 Оеѵеіорег или Адѵапсед. 



(* ОеІрЬі ВесІагаСіопз іог СКРЕ{32).БЬЬ 

•к к 


•к * 

★ ★ 

■к -к 

■к ■к 

кк 

** 

•к к 

■к к 

к к 


Рііе : СКОЕЬРНІ . РАЗ 

АиСЬогз і Датез Апдегзоп, Апдге СоиСигіег, Ргапк гігатегтап 
ШСе : 14 ОсС 1999 

Ригрозе : ТЬіз іііе ргезепСз СЬе АРІ Со сЬе СгузСаІ Керогсз 

РгіпС Епдіпе ПЬЬ. ТЬіз іііе адііі сощрііе апд ехесиСе іп 
ОеІрЬі 1, 2, 3, 4 апд 5. 

Ьапдиаде : ОеІрЬі 1, 2, 3, 4 апд 5. 

СоругідЬе (с) 1991-1999 ЗеадаСе ЗоіСмаге ІпіогшаЬіоп МападвпепЬ Сгоир, Іпс. 


** КЬСез: ТЬіз іііе ѵгі.11 сгеаЬе а СКОЕЬРНІ.ЮТ адЬеп уои изе сспрііе апд Ьиіід. 
** То изе СЬе СКОЕЬРНІ .СОТ, уои таіі пеед Со адд ЬЬе іоііовдіпд Ііпе 

** оі соде Со уоиг ’изез' зесСіоп оі уоиг БеІрЬі аррІісаСіоп 

** ед. 

** изез 

** Сіаззез, СКБЕЬРНІ, 

★ к 

** ДРБАТЕЗ оп КЬѵешЪег 23гд, 2000 
** Аддед Ъу Тгеѵог БиЬіпзку 

к к 


** 4ддѳд десІагаСіопз, Сурез апд сопзСапСз гесзиігед іог іоіісадіпд іипсСіоп саііз: 
** іипсСіоп РЕОеСКерогСѴегзіоп 
** іипсСіоп РЕСЗеШКерогСАІегСз 
** іипсСіоп РЕСеС№ЬКерогСА1ег(: 

** іипсСіоп РЕСеШСЬАІегСіпзСапсеІпіо 
** іипсСіоп РЕ5ее№ЪАІегССопді1:іопРогти1а; 

** іипсСіоп РЕ5еС№іЬАІегШеззадеРогти1а,- 
іипсеіоп РЕЗеС№ЬАІегОЭеіаи1Шеззаде; 


** 
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** гипсЫоп РЕЕпаЪІеЦспАІегІ:; 


При разработке приложения с помощью Ѵіхиаі Вахіс можно поступить так 
же, как и при работе в ОеІрЬі. Только для импорта списка функций и типов 
к проекту необходимо подключить два модуля С1оЬа132.Ьа5 и Спѵгар.Ьах, ко¬ 
торые находятся в том же самом каталоге, что и СіШеІрЬі.рах. 




штжтж 




Ѵізиаі Вазіс БесТагаЫопз оі СКРЕ32.ЬЬЬ 


Рііе: СЬОВАЬЗ 2.ВАЗ 

АиЙюг: ЗеадаСе ЗоіСадаге ІпіоггпаЬіоп МападетепЬ Сгоир, Іпс. 

Басе: 15 Арг 92 

Ригрозе: ТМз іііе ргезепьз Ьііе АРІ Ьо Ыіе СгузЬаІ Керогьз 

РгіпС Епдіпе БЫ (РгоіеззіопаІ) . 

Ьапдиаде: Ѵізиаі Вазіс іог Иіпдовдз 

СсругідЫ: (с) 1992 - 1999 ЗеадаСе Зойзлаге Іп&шаЬісп Шпадетзіі: Огоир, Іпс. 


- ' '•> “Щ 


Ѵізиаі Вазіс БесІагаЬіопз оі сгшгар32.ВЬЬ 


Рііе: сгѵлгар.ВАЗ 

АиЫіог: ЗеадаЬе ЗоіСадаге ІпіогтаЬіоп МападетепЬ Огоир, Іпс. 


Ьапдиаде: 


Ѵізиаі Вазіс іог Иіпйоід73 
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ОсругідЫ: (с) 1992 - 1999 ЗѳадаСе Зойзлаге ІпісаашСісп МападшяіЬ Сгоир, Іпс. 


Кеѵізіопз: 

ЗМ- Ыоѵ 99, гешоѵей оЬзоІеее ехрогьіпд іогшаьз 
Ехсеі 2.1 

СІоЬаІ Сопзс сгИХРХ1з2Туре% = О 
Ехсеі 3.О 

СІоЬаІ Сопзе сгИХРХ1зЗТуре% = 1 
Ехсеі 4.О 

СІоЬаІ Сопзь сгЦХРХ1з4Туре% = 2 
НТМЬ 3.0 

СІоЬаІ СопзС сгЦХРНТМЬ3Туре% = 0 ' НТМЬ 3.0 Ьадз 


СопзСапСз апд РипсЬіоп Оеііпісіопз і. ог ЕхрогЬіпд 


Примечание ^ 

После подключения указанных файлов к проекту необходимо откорректировать 
файлы. В тех строчках, которые содержат приблизительный путь к библиоте¬ 
кам сгре32.й11 и сгѵ/гар.йІІ, необходимо указать действительный путь. Если этого 
не сделать, то приложение работать не будет. 


После подключения указанных файлов к проектам Оеіріті и Ѵізиаі Вазіс, 
можно приступить к реализации приложения. Для начала желательно соз¬ 
дать экранную форму, как это показано на рис. 9.1 и 9.2. 

Для удобства работы установим параметры экранной формы, как в табл. 9.1 
или в табл. 9.2. 

Таблица 9.1. Установка параметров экранной формы в проекте ОеІрЫ 


Элемент Наименование 

Экранная форма СВѴѴ_АРІ_Рогт 

Кнопка ЫпЗІгоѵѵВерогі 

Диалог. Компонент ВерогізОрепОіаІод 
ОрепЭіаІод 


Заголовок 

Использование Сгузіаі Верой Епдіпе АРІ 

Показать отчет 

Открыть отчет Сгузіаі Верой 










Рис. 9.1. Проект и экранная форма ОеІрНі 



Рис. 9.2. Проект и экранная форма ѴізиаІ Вазіс 
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У компонента типа ОрепОіа1о§ с именем Керогі$ОрепОіа1о§ желательно ус¬ 
тановить фильтр. Для этого необходимо установить фокус на этот компо¬ 
нент в экранной форме и, перейдя в редактор ОЪ]ес( Іпяресіог, дважды 
щелкнуть левой клавишей мыши в поле с названием ЕШег. При этом поя¬ 
вится диалоговое окно, в которое необходимо ввести значения так, как это 
показано на рис. 9.3. 


ГіІІег Есіііог 


ЯНеШате, 

}га<« ' ’ И 


*.Гр( 


Все Файлы 


Д1І 


СЖ 


Л Сапсеі Неір 


Рис. 9.3. Настройка параметров фильтрации выбираемых файлов ОеІрЬі 


Таблица 9.2. Установка параметров экранной формы в проекте ѴізиаІ Вазіс 


Элемент 

Наименование 

Заголовок 

Экранная форма 

СВѴѴ_АРІ_Рогт 

Использование СгузіаІ Перогі Епдіпе АРІ 

Кнопка 

ЬіпЗЬоѵѵВерогі 

Показать отчет 

Диалог. Компонент 
СоттопОіаІод 

ВерогіОрепОіаІод 

(СоттопОіаІод) 

Открыть отчет СгузіаІ Верогі 


У компонента типа СоттопОіа1о§ с именем КерогЮрепПіа1о§ так же, как и 
при работе в ОеІрЬі, желательно установить значение фильтра. Для этого 
необходимо вызвать контекстное меню компонента и выполнить команду 
Ргорегііея В открывшемся диалоговом окне Ргорегіу Ра§ез на вкладке 
Ореп/8аѵе Аз вписать информацию так, как это показано на рис. 9.4. 

Далее можно приступить к описанию алгоритма вызова отчетов СгузіаІ 
Керогі 9 нажатием кнопки Показать отчет. В обоих примерах компоненты 
КероітОрепОіа1о§ служат для выбора отчета, который необходимо открыть. 

^ Примечание 

Все функции СгузіаІ Нерогі Епдіпе АРІ именуются по общему принципу. Первые 
две буквы наименования функции или процедуры всегда РЕ, например, 
РЕОрепЕпдіпе. Описание функций можно найти в Приложении 1. 
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Рис. 




Схема 9.1. Алгоритм просмотра отчетов Сгузіаі ЯерогТз 9 из приложения 
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Для удобства работы рекомендуется в разделе глобальных переменных объя¬ 
вить следующую переменную: 

□ Для проекта БеІрЫ — пРгіпііоЪ, тип данных Ѵ/огсі; 

□ Для проекта ѴівиаІ Вавіс — пРгіпьіоЬ, тип данных 1гПе§ег. 

В данном примере будет использовано всего четыре функции: 

□ РЕОрепЕпфпе — загрузка компонентов Сгухіаі Ргіт Еп§іпе; 

□ РЕОрепРгіпЕГоЬ — загрузка в память выбранного отчета; 

□ РЕОиіриіТоХѴіпёоѵѵ — настройка параметров окна просмотра отчетов; 

□ РЕ8іагіРгіпУоЬ — запуск отчета на просмотр. 

Блок-схема алгоритма работы с отчетами представлена на схеме 9.1. 

В листингах 9.4 и 9.5 дан текст процедур, реализующих алгоритм, представ¬ 
ленный на схеме 9.1. 

І Листинг 9.4. Проект в ОеІрЬі, содержащий описание основных объектов и процедур ; 

ипіс МаіпРогт,- 

іпеегГасе 

иаез 

Иіпсіоюз, Меззадез, ЗузЦЬіІз, Ѵагіапбз, Сіаззез, СгарЬісз, СопЬгоІз, Рогтз, 
Ціаіодз, ЗббСбгІз; 

ЬУРѲ 

ТСКИ_АР1_Ронп = сіавз (ТРогт) 

ЪбпЗЬои'Керог): : ТВиббоп; 

КерогбзОрепБіаІод: ТОрепБіаІод; 

ргосейиге Ъбп5Ъоіл7КерогбС1іск(5епс1ег: ТОЬдесб) ; 

ргіѵабе 

{ Ргіѵабе бесіагабіопз } 

риЫіс 

{ РиЫіс бесіагабіопз } 

ѲПЙ; 

ѵаг 

СКИ_АРІ_Рогш: ТСКИ_АРІ_Рогш; 

пРгіпбОЪЪ: Иогб; {Переменная, в которую присваивается номер обрабаты¬ 
ваемого отчета} 
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ілрІетепГаЪ іоп 
изеа СКОеІрЬі; 

{$К *.й&і} 

ргосейиге ТСКИ_АРІ_Рогт.Ы:п5Ьо\л7Керог(:СІіск(Зепйег : ТОЪзесД); 

Ъедіп 

Іі Керог 1: зОрепЛі а 1 од. Ехеси (: е ТЪеп 
Ведіп 

{Попытка запуска Сгузбаі Керогбз Ргіпб Епдіпе. 

Если запуск не удался, то выдается сообщение об ошибке.} 

ІИ РЕОрѳпЕпдіпе ТЬѳп 
Ведіп 

{При корректном запуске Сгузбаі Керогьз Ргіпб Епдіпе 
выполняется попытка загрузить выбранный отчет. 

Если не удается загрузить отчет, то выдается сообщение об ошибке.} 
пРгіп^оЪ: =РЕОрѳпРгіпЪЛоЬ(РСЬаг (КерогДзОрепЛіаХод. РНеИате) ) ; 

ІЕ пРгіпЫОЬ^О ТЪеп 
ЗЬоиМеззаде ('Ошибка открытия отчета') 

Еізе 

Ведіп 

{Установка базовых характеристик окна просмотра отчета.} 

РЕОиЬрцЬТоИіпйом(пРгіпГЛОЬ, 

РСЬаг(КерогбзОрепВіаІод.РіІеМате), 0,0,0,0, 
МЗ_МАХІМІ2Е+ИЗ_МІМ!ІМІ2ЕВ0Х+И8_МАХІМІ2ЕВ0Х+И5_8У5МЕІ'ГО, 0) ; 

{Комментарий - РЕОи(:ри(:ТоМіпсіо\»;( Значение, возвращаемое функцией 
РЕОрепРгіпЫоЬ, 

Заголовок открываемого окна просмотра, 

Координата X верхнего левого угла. Координата У 
верхнего левого угла, 

Ширина окна просмотра, Высота окна просмотра. 

Стиль окна просмотра (флаги могут быть перечислены 
через "ОК"), 

Указатель на родительское окно);} 

{Запуск на просмотр выбранного отчета с определенными параметрами.} 
РЕЗЪагЪРгіпЪО'оЬ (пРгІпГіТоЬ, ТР.ЦЕ) ; 

ѳпй 

епй 

Еіае 
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ЗЬоиМеззаде('Ошибка запуска СК КерогД Епдіпе'); 

епй; 

епй; 

еікЗ. 



Віт пРгіпРиТоЬ Аз Іпбедег ' Переменная, которой присваивается номер обра¬ 
батываемого отчета 


Ргіѵабе ЗиЬ Ъбп8Ъои'Керог(:_СІіск () 

Біт гези11:% 

Керог бОрегШіаІод . ЗЬоѵіЮреп 
I і. КерогбОрепСіаІод.ііІеЫате о Тііеп 

'Попытка запуска Сгузбаі Керогбз Ргіпб Епдіпе. 

'Если запуск не удался, то выдается сообщение об ошибке. 

ІЕ РЕОрепЕпдіпе ТЬеп 

'При корректном запуске СгузЬаІ КерогЬз РгіпД Епдіпе 
'выполняется попытка загрузить выбранный отчет. 

'Если не удается загрузить отчет, то выдается сообщение об ошибке. 
пРгіпЫоЪ = РЕОрепРгіпЬСГоЪ (КерогДОрепБіаІод. ііІеНаше) 

Іі пРгіпЫоЪ = 0 ТЬеп 

МздВох ("Ошибка открытия отчета") 

Еізе 

'Установка базовых характеристик окна просмотра отчета. 

гези1(:% = РЕОиРриРТоМіпйо'М (пРгіпбьГоЬ, 
КерогДОрегШіаІод.ІіІеКаіпе, О, О, О, О, 

ИЗ_МАХІМІ2Е + НЗ_М!ЩІМІ2ЕВОХ + И5_МАХІМІ2;ЕВОХ + И8_8У5МЕШ, 0) 

'Запуск на просмотр выбранного отчета с определенными 
параметрами. 

гези1б% = РЕЗЪагЪРгіпЪіТоЬ (пРг іпЫЪЬ, Тгие) 

Епб. Іі 

Еізе 

МздВох ("Ошибка запуска СК КерогЬ Епдіпе”) 

Епсі I і 
Епй I і 
Епй ЗиЬ 
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После отладки и компиляции представленного в листингах кода можно за¬ 
пустить полученные приложения и посмотреть, что получилось. В момент 
запуска внешний вид экранных форм должен быть таким, как показано 
на рис. 9.5 и 9.6. 


♦Г Использование СгуЛаі К: 




'■ .-І.пі хі 


Пример вызова отчета СгузГаІ Нерог) из 
приложения написанного на ОеІрНі 


Показать отчет 


Рис. 9.5. Приложение, реализованное с помощью РеІрГіі 


, Использование ОузІЫ К 




•|Р|ХІ 


Пример вызова отчета Сгузіа! В.ероЛ из 
приложения написанного на ѴізиаІ Вазіс 


Показать отчет 


Рис. 9.6. Приложение, реализованное с помощью ѴізиаІ Вазіс 


Внешне обе экранные формы абсолютно идентичны, и различия между 
программами минимальны. Это говорит о том, что обе программы должны 
работать одинаково. При нажатии кнопки Показать отчет в любом из при¬ 
ложений появится стандартный диалог операционной системы, предлагаю¬ 
щий выбрать файл отчета для отображения в окне просмотра. После выбора 
файла и нажатия кнопки Открыть (Орел) результат будет выглядеть так, как 
это показано на рис. 9.7. 


^ Примечание 

Результат будет аналогичен в случае, если в качестве среды разработки ис¬ 
пользовались не Оеіріті или ѴізиаІ Вазіс, а любое другое средство разработки. 

Упражнение 9.1 

Создайте на основании описанных примеров программу в ОеІрЫ, ѴізиаІ 
Вазіс или другом средстве разработки приложений и посмотрите ре¬ 
зультат. 
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Рис. 9.7. Отчет СгузіаІ Яерогі 9, открытый в стандартном окне просмотра 
с помощью приложения, написанного в ОеІрЬі или ѴізиаІ Вазіс 


9.2.2. Вызов отчетов СгузіаІ Верогіз из приложений. 
Настройка параметров окна просмотра отчетов 
с помощью функций СгузіаІ Верогі АРІ 

Предыдущие примеры показали, как можно с помощью функций СгузіаІ 
Яероп 9 Еп§іпе АРІ выбрать любой отчет и открыть его для просмотра и 
дальнейшей печати. Однако не всегда удобно работать с отчетами в стан¬ 
дартном окне просмотра, содержащем минимум функциональности и не 
всегда дающем возможность использовать ряд специфических характеристик 
самого отчета. К наиболее важным из таких характеристик относятся: 

□ наличие группирования и возможность навигации по дереву групп; 

□ создание ОНИ По\га отчетов; 

□ экспорт; 

□ поиск. 
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Для того чтобы иметь возможность управлять настройками окна просмотра 
отчетов необходимо внести ряд изменений в алгоритм и созданное ранее 
приложение. Блок-схема алгоритма представлена на схеме 9.2. 



Схема 9.2. Блок-схема алгоритма, позволяющего произвести 
настройку параметров окна просмотра 


Как видно из блок-схемы, в алгоритм добавилась еще одна функция — 
РЕ$е(ЛѴтсіоѵѵ$Орііоп$, которая потребует внесения дополнительных элемен¬ 
тов управления в ранее описанные примеры. Во-первых, потребуется изме¬ 
нить внешний вид экранной формы, добавив 12 элементов типа СНескВох. 
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Эти элементы позволят устанавливать параметры окна просмотра отчета 
непосредственно перед выбором самого отчета. Экранные формы будут вы¬ 
глядеть так, как это показано на рис. 9.8 и 9.9. 


| Использование Сі-уйаі Перой 

цДШІХ]і 

ірЛ Пример вызова отчета СгузіаІ Верой из 
стгсіі приложения написанного на ОеІрЬі 

: Г* Дерево групп Г" Отмена 

І ■ 

1 

! Г* ОгШ Ооѵѵп 

Г* Закрыть 


; Г* Элементы навигации 

Г" Отображение прогресса загрузки | 

: Г Форматирование 

Г* Экспорт 

1 

\ Обновить 

Г~ Печать 

і • 

! 

Г" Поиск 

Г* Настройки принтера 

І 

• Показать отчет 

—■ 

■■■■■■■■■■ 

_1 


Рис. 9.8. Внешний вид экранной формы для выбора параметров окна 
просмотра отчета в ОеІрИі 



ві. Использование Сгуйаі НерогГ 


.=151 х] 


щи Пример вызова отчета СгузіаІ Верой из 
приложения написанного наѴізиаІ Вазіс 

Г П араметры окна просмотра отчетов— 1 -— т - т— 

I Г” Дерево групп Г” Отмена 


Г~ ОгіІІ Оо'лп Г” Закрыть 

Г” Элементы навигации Г - Отображение прогресса загрузки 

Г~ Форматирование Г* Экспорт ' 


Г* Форматирование 
Г* Обновить 
Г” Поиск 


Г” Печать 

Т Настройки принтера 


Показать отчет 



Рис. 9.9. Внешний вид экранной формы для выбора параметров окна 
просмотра отчета в ѴівиаІ Вазіс 


Для удобства использования представленных далее листингов добавленные 
элементы интерфейса желательно назвать так, как это описано в табл. 9.3. 
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Таблица 9.3. Настройка параметров экранной формы в проекте ОеІрЫ 


Тип объекта 

Название 

Текст, видимый на экране (Сарііоп) 

СЬескВох 

сЬСгоирТгее 

Дерево групп 

СЬескВох 

сЬОЫЮоѵѵп 

ОгіІІ Ооѵлі 

СЬескВох 

сЬЫаѵідаііоп 

Элементы навигации 

СЬескВох 

сЬРогта* 

Форматирование 

СЬескВох 

сЬВеДезЬ 

Обновить 

СЬескВох 

сЬЗеагсЬ 

Поиск 

СЬескВох 

сЬСапсеІ 

Отмена 

СЬескВох 

сЬСІозе 

Закрыть 

СЬескВох 

сЬРгодгезз 

Отображение прогресса загрузки 

СЬескВох 

сЬЕхрогі 

Экспорт 

СЬескВох 

сЬРгіпІ 

Печать 

СЬескВох 

сЬРгіпІегЗеІир 

Настройка печати 


Перечисленные в таблице элементы для Оеірііі и Ѵі$иа1 Ваыс идентичны. 

После модификации формы можно приступать к изменению текста про¬ 
граммы. Для установки параметров окна просмотра отчета нам потребуется 
вызов функции РЕЗеІ^іпсІохѵОрГюпз и, поскольку один из параметров ее 
имеет тип РЕ\Ѵіпсіо\ѵОрІіоп5, необходимо декларировать переменную Ѵіе\ѵ- 
егОрІіоп этого типа. Далее потребуется проверка состояния каждого элемен¬ 
та типа СЬескВох и присвоение соответствующих значений элементам пе¬ 
ременной ѴіехѵегОрбоп. Текст программы будет выглядеть так, как это 
показано в листингах 9.6 и 9.7. 

І Листинг 9.6. Отредактированная программа в ОеІрЫ, реализующая алгоритм 
; просмотра отчетов в настраиваемом окне просмотра. Цветом выделены 
;. внесенные в предыдущий пример изменения 

ипіе МаіпРогш,- 

ігЛегГасѳ 

игѳг 

Иіпсісвдз, Меззадез, ЗузІЖіІз, ѴагіапЬз, Сіаззез, СгарЬісз, СопЬгоІз, Рогтз, 
Оіаіодз, ЗЬйСЬгІЗ; 
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Ъуре 

ТСКИ_АР1_Рогт = сіавв (ТРогт) 

ЬЬпЗЪоадКерогІ: : ТВиЫоп; 

КерогДзОрепГііаІод: ТОрепВіаІод; 

ЬаЬеІ 1: ТЬаЬеІ; 

СгоирВохІ: ТСгоирВох; 
сЬОгоирТгее: ТСЪескВох; 
сЪ0гі1ІВоѵт: ТСЪескВох; 
сЪМаѵідаЬіоп: ТСЪескВох; 
сЪРогтаЬ: ТСЪескВох; 
сЪКеігезЪ: ТСЪескВох; 
сЪЗеагсЪ: ТСЪескВох; 
сЪСапсеІ: ТСЪескВох; 
сЪСІозе: ТСЪескВох; 
сЪРгодгезз: ТСЪескВох; 
сЪЕхрогЬ: ТСЪескВох; 
сЪРгіпЬ: ТСЪескВох; 
сЪРгіпЪегЗеЪир: ТСЪескВох; 

ргосе<іигѳ ЬЪпЗЪоѵКерогЪСІіск (Зепбег : ТОЪэесЪ) ; 

ргіѵаЬе 

{ РгіѵаЬе десіагаьіопз } 

риЫіс 

{ РиЫіс йесІагаЬіопз > 

ѳпд; 

ѵаг 

СКМ_АРІ_Рогш: ТСКМ_АРІ_Рогт; 

пРгіпЫоЪ: Иогй; {Переменная- указатель на выполняемый отчет} 

ітрІетегЛаРіоп 

ивеа СЕБеІрЪі; 

{$К 

ргосѳйигѳ ТСКИ_АРІ_Рогт.ЪЫЗЪоѵі7КерогРС1іск (Зепбег : ТОЪ^есЬ) ; 

ѵаг 

ѴіеѵгегОрЬіоп: РЕИіікЗомОрЬіопа ; {Переменная, используемая для 
установки дополнительных параметров окна просмотра отчетов} 
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Ьедіп 

Іі КерогЬзОрепОіаІод.ЕхесиЬе ТЪеп 
Вѳдіп 

{Попытка запуска Сгузіаі Керогіз Ргіпі Епдіпе. 

Если не удалось, то выдается сообщение об ошибке . } 

Іі РЕОрепЕпдіпе ТЬеп 

Ведіп 

{При корректном запуске Сгузіаі Керогіз Ргіпі Епдіпе 
выполняется попытка загрузить выбранный отчет. 

Если не удается загрузить отчет, то выдается сообщение об ошибке.} 
пРгіпЫоЪ: =РЕ0репРгіпі.7оЪ(РСЪаг (КерогізОрепБіаІод.ЕіІеНате) ) ; 

Іі. пРгіпііТоЪ=0 ТЬеп 
ЗЪонМеззаде('Ошибка открытия отчета') 

Еіае 

Ведіп 

{Установка базовых характеристик окна просмотра отчета.} 

Р.ЕОиіриіТоМіп<Зом (пРгіпОИоЬ, 

РСііаг (КерогізОрепСіаІод.РіІеЫате) , 0,0,0,0, 
ИЗ_МАХІМІ2Е+И5_МШІМІ2ЕВ0Х+И5_МАХІМІ 2ЕВОХ+И5_ЗУЗМЕШ, 0) ; 

{Комментарий - РЕОиіриіТоНіпйоад{ Значение, возвращаемое функцией 
РЕОрепРгіпіОоЪ, 

Заголовок открываемого окна просмотра, 

Координата X верхнего левого угла. Координата У 
верхнего левого угла. 

Ширина окна просмотра. Высота окна просмотра. 
Стиль окна просмотра(флаги могут быть перечислены 
через "ОК"), 

Указатель на родительское окно);} 

{Проверка состояния СЪескВох-ов и 
настройка параметров окна просмотра отчета} 

Іі сЬСЗгоирТгее. СЬескей Иіеп 

ѴіеѵгегОрііоп.ІіазСгоирТгее := 1 

еізе 

ѴіеадегОрііоп.ЪазСгоирТгее := 0; 

Іі сЬВгіІІВоѵт.СЬескей ТЪеп 

ѴіевдегОрііоп.сапВгіІІВодаі :=1 
еізе 

ѴіеѵгегОрііоп. сапБгіІІВоѵт :=0; 

Іі сШаѵідаііоп.СЪескей Иіеп 

Ѵіеѵ/егОрііоп.ІіазНаѵідаііопСопігоІз : =1 
еізе 

ѴіемегОрііоп.ЪазШѵідаііопСопігоІз : =0; 
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Іі сЬСапсеІ .СЬескед ТЬеп 

ѴіеѵгегОрЬіоп.ЬазСапсеІВиЬЬоп :=1 
еізе 

ѴіеадегОрЬіоп. ЬазСапсеІВиЬРоп : =0 ; 

I і. сЪРгіпЬ.СЬескед ТЬеп 

Ѵіеи'егОрРіоп.ЬазРгіпЬВиЬРоп :=1 
еізе 

ѴіевдегОрЬіоп .ЬазРгіпЬВиЬЬоп :=0; 

ІЕ сЪЕхрогД. СЬескед ТЬеп 

ѴіевдегОрЬіоп.ЬазЕхрогДВиДДоп :=1 
еізе 

ѴіевдегОрЬіоп.ЬазЕхрогДВиДДоп :=0; 

ІЕ сЪРогтаД.СЬескед ТЬеп 

ѴіеадегОрЫоп.ЬазгоотСопкгоІ : = 1 
еізе 

ѴіемегОрДіоп.Ьаз2оотСопДхо1 :=0; 

ІД сЪСІозе.СЬескед ТЬеп 

ѴіеѵгегОрДіоп.ЬазСІозеВиДДоп :=1 
еізе 

ѴіездегОрДіоп.ЬазСІозеВиДЬоп :=0; 

ІИ сЬРгодгезз.СЬескед ТЬеп 

ѴіеадегОрДіоп.ЬазРгодгеззСопДгоІз :=1 
еізе 

ѴіеадегОрДіоп.ЬазРгодгеззСопДгоІз :=0; 

ІД сЪЗеагсЬ.СЬескед ТЬеп 

ѴіеадегОрЬіоп.ЬазЗеагсЬВиДДоп :=1 
еізе 

ѴіеѵгегОрЬіоп.ЬазЗеагсЬВиДДоп :=0; 

Іі сЪРгіпДегЗеЬир.СЬескед ТЬеп 

ѴіеадегОрЬіоп.ЬазРгіпЬЗеДирВиДДоп :=1 
еізе 

ѴіеѵгегОрЬіоп.ЬазРгіпЬЗеЬирВиДДоп :=0; 

I і сЪКеДгезЬ.СЬескед ТЬеп 

Ѵіеіл/егОрЬіоп.ЬазКеДгезЬВиДДоп :=1 
еізе 

ѴіеѵгегОрДіоп.ЬазКеДгезЬВиЬДоп :=0; 

Ѵіеіл/егОрДіоп. ЗДгисЬЗіге := РЕ_ЗІ2ЕОР_ИІЫІЮИ_ОРТІОЫЗ; {Константа, 

равная 32} 

{Передача заданных характеристик в окно просмотра отчета} 
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РЕЗеШіпДомОрСіопв (пРгіпЫоЬ,ѴіеиегОрЬіоп) ; 


•■і/ 

{Запуск на просмотр выбранного отчета с определенными параметрами.} 
РЕБРагРРгіпЪіТоЪ(пРгіпЬіТоЬ, ТГОЕ) ; 
епй 
епд 
Еіве 

ЗЬонМеззаде('Ошибка запуска СК Керогс Епдіпе'); 

епй; 

епй,- 

еп<3. 


; Листинг 9.7, Отредактированная программа в ѴізиаІ Вазіс, реализующая 
| алгоритм просмотра отчетов в настраиваемом окне просмотра. Цветом 
і выделены внесенные в предыдущий пример изменения 


Оіт пРгіпРТоЪ Аз Іпбедег 'Переменная-указатель на выполняемый отчет 


Ргіѵабе ЗиЬ Ъбп5ЬоадКерогІ;_СІіск () 

Оіт гези1б% 

Оіт ѴіеадегОрбіопз Аз РЕИіпдоѵЮрбіопз 'Переменная, используемая для 
установки дополнительных параметров окна просмотра отчетов 


Керог ЬОрегШіаІод. ЗЬоадОреп 

Іі. КерогЬОрегШіаІод. іЕНеИате <> "" ТЬеп 

'Попытка запуска СгузРаІ Керогбз Ргіпб Епдіпе. 

'Если не удалось, то выдается сообщение об ошибке. 

ІЕ РЕОрѳпЕпдіпе ТЬеп 

'При корректном запуске Сгузбаі КерогЬз РгіпЬ Епдіпе 
'выполняется попытка загрузить выбранный отчет. 

'Если не удается загрузить отчет, то выдается сообщение об ошибке. 
пРгіпЫоЪ = РЕОрепРгіпРіТоЪІКерогбОрепРіаІод. ііІеЫате) 

I і пРгіпЫоЪ = 0 ТЬеп 

МздВох ("Ошибка открытия отчета”) 

Еізе 

'Установка базовых характеристик окна просмотра отчета. 

гези1Ь% = РЕОиЪриЪТоМіпйсгк (пРгіпДОЪЪ, 

КерогЬОрепБіаІод. ЕіІеИаіпе, О, О, О, О, 

И8_МАХІМІ2Е + ИЗ_МІНІМІ2ЕВОХ + ИЗ_МАХІМІ2ЕВОХ + МЗ_ЗУ5МЕТО, 0) 
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'Проверка состояния СЪескВох-ов и 
'настройка параметров окна просмотра отчета 

ІІ сЬСгоирТгее ТЪеп 
ѴіеадегОрІіопз .ЪазОгоирТгее = 1 
Еізе 

ѴіевдегОрЬіопз .ЪазСгоирТгее = О 
Епй II 

II сЬРгіІЮоѵт ТЪеп 
Ѵіеѵо'егОрЬіопз.сапБгіІІРоѵт = 1 
Еізе 

ѴіевдегОрІіопз. сапІ)гі11Воѵт = О 
Еп<3 I I 

ІІ сШаѵідаЬіоп ТЪеп 
ѴіеиегОрІіопз.ЪазЫаѵідаІіопСопігоІз = 1 
Еізе 

ѴіеадегОрІіопз.ЪазКаѵідаІіопСопІгоІз = О 
Епа II 

II сЬРогшаЬ ТЪеп 

ѴіеѵгегОрІіопз.ЪазЕоотСопігоІ = 1 
Еізе 

ѴіеѵігегОрІіопз .Ъаз2оотСопІго1 = О 
Епсі II 

ІІ сЪКеІгезЪ ТЪеп 

ѴіеадегОрІіопз.ЪазКеІгезЪВиІІоп = 1 
Еізе 

Ѵіеѵі/егОрЬіопз .ЪазКеІгезЪВиІІоп = О 
Епй I I 

ІІ сЪЗеагсЪ ТЪеп 

ѴіевдегОрЬіопз.ЪазЗеагсЪВиІІоп = 1 
Еізе 

ѴіемегОрЫопз.ЪазЗеагсЪВиІІоп = О 
Епй II 

ІІ сЬСапсеІ ТЪеп 

Ѵіеіл/егОрЪіопз .ЪазСапсеІВиІЬоп = 1 
Еізе 

ѴіевдегСрЬіопз.ЬазСапсеІВиРЬоп = О 
Епй II 

ІІ сЬСІозе ТЪеп 

Ѵіевд'егОрЬіопз.ЪазСІозеВиІЬоп = 1 
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Еізе 

ѴіеадегОрііопз.ЬазСІозеВчііоп = О 
Епсі Іі 

Іі сЬРгодгезз ТЬеп 

ѴіевдегОрііопз.ЬазРгодгеззСопігоІз = 1 
Еізе 

ѴіевдегОрііопз.ЬазРгодгеззСопігоІз = О 
Еп<3 Іі 

Іі сЬЕхрогі ТЬеп 

ѴіевдегОрьіопз.ЬазЕхрогіВиііоп = 1 
Еізе 

ѴіевдегОрііопз.ЬазЕхрогіВиііоп = О 
Еп<3 Іі 

Іі сЬРгіпі ТЬеп 

ѴіеадегОрііопз.ЬазРгіпіВиііоп = 1 
Еізе 

Ѵіеіл/егОрііопз.ЬазРгіпіВиііоп = О 
■ ЕпЦ Іі 

Іі сЬРгіпіегЗеіир ТЬеп 
Ѵіеіл/егОрііопз.ЬазРгіпіЗеіирВиііоп = 1 
Еізе 

ѴіевдегОрііопз.ЬазРгіпіЗеіирВиііоп = О 
Епсі Іі 

ѴіездегОрііопз . ЗігисрЗіге = РЕ_5І2ЕОЕ_МітЭК_ОРТІСЖ5 
гези1і% = РЕЗеШіпйоѵіЮрііопз (пРгіпЬДоЬ, ѴіеѵгегОрііопз) 

'Запуск на просмотр выбранного отчета с определенными параметрами. 
гези1і% = РЕЗіагЪРгіпЪіІоЫпРгіпЫоЬ, Тгие) 

Еп<3 Іі 

Еізе 

МздВох ("Ошибка запуска СК Керогі Епдіпе") 

Епй Іі 
Епй Іі 
Епй ЗиЬ 

Как видно из приведенных листингов, для реализации механизма передачи 
параметров окна просмотра, необходимо внести минимальные изменения. 
Большее время будет затрачено на выполнение чисто механической работы 
по внесению большого количества строк. После изменения текста можно 
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запустить полученную программу и посмотреть результаты, которые будут 
получаться при активизации одного или нескольких СЬескВох. Результат 
вызова отчета после активирования всех СЬескВох показан на рис. 9.10. 


ФО:\Ргодгаоі ГІ1е5\5еадаСе 5<ЯЪчоге\Сгу5Іаі 




X \4 А ІоП 
Ріеѵіе* і 

& беодгарЫс Ваіеі Парой 

ёі Р АийгаІ» 

Ж Р ИеіѵВоіЛНѴѴаІе® 
Р биеетіалсі 
Р Вгі$Ьапе 
Й*Р Тазтапіз 
Ж • Р Ѵюіогіа 
К Р Ѵ/е5Іет АиЛіаБа 
[♦> Р Аийгіа 
Ж Р Вапд1ас1е$Ь 
ЙО- Р Вгагіі 
ЙѴ Р Сапагіа 
Й р СЬІпа 

®-Р биапдбопд 
аз- Р Нопд Копд 
• !*! • Р ЗКапдпаі 

В Р ЗюЬиао 

Р СЬвпдсІи 
Ж Р Тіапііп 
Г*> Р СоЛа Нюа 
ЙѴ Р СгесЬ ПериЫіс 

Ш'Р Едурі 

Йг Р ргапсе 
Уі Р Ееіталу 
Ш Р Нипдагу 
[♦1 Р Ігкіа 
Ж Р КФ 
Ш Р Кепуа 
Й1 Р ІихетЬоид 
Г+1 Р Маіауоіа 
$ Р Мехісо 
Зз-Р МопдоГіа 
Ж Р Иераі 
® Р ЫІсаіадиа 
Ж Р РакЫао 
>’*;■ Р Рапагпз 
К Р Реги 
1*1 Р Роіапгі 
Ж Р Роііида) 



ТоЫ.203 - 1002 


ѴГогИ 

ія <*см«ж«ажіѵ»*» ах 

ігяосшьазіаша о» 

I 5ПЗОШ2Э60ШС Я> 

I «О СШЬ 5ТШЕ0 (I) 

і «аешь іашш ог> 


ѴѴопа 531е$ СгатГГоІаІ: 6 543 723,17 


Рис. 9 . 10 . Окно просмотра отчета, содержащее все доступные элементы управления 


Упражнение 9.2 

Внесите необходимые изменения в написанное ранее приложение и по¬ 
смотрите результат. 

9.2.3. Обработка отчетов с параметрами. 
Использование Сгузіаі Перогі АРІ 

Часто при работе с отчетами обнаруживается, что вызываемый отчет должен 
содержать один или несколько параметров. Для того чтобы эти параметры 
можно было обрабатывать непосредственно в приложении, а не в момент 
загрузки отчета, существует большой набор функций. Работу некоторых из 
них мы рассмотрим в предлагаемых примерах. 
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Чтобы рассмотреть один из вариантов обработки отчета с параметром, необ¬ 
ходимо создать отчет на основании данных из тестовой базы хІгете.тсІЪ. 

Выполните следующие действия: 

1. Подключитесь к базе данных хігете.тсіЪ. 

2. Выберите таблицу Си$1отег. 

3. В таблице выберите поля Сизіотег Ыате, Сопіасі Тіііе, Сопіасі Рігзі 
Ыате, Сопіасі Ъазі №те и Ьазі Ѵеаг’$ 8а1е$. 

4. Отформатируйте полученный отчет. 

5. Создайте поле параметр с названием "Условие группировки", типом дан¬ 
ных 8ігіп§, подсказкой "Условие группировки. Впишите в поле букву: 
С — группировка по стране, К — группировка по региону, 8 — группи¬ 
ровка по городу" и значениями по умолчанию - С, К и 5 так, как это 
показано на рис. 9.11 и 9.12. 

6. Создайте поле формулу, под названием "Формула группировки". Текст ее 
представлен в листинге 9.8. 

7. Сгруппируйте отчет по созданному полю формуле. 

8. Результат должен быть похож на вариант, показанный на рис. 9.13. При 
каждом повторном запуске этого отчета или при выполнении операции 
обновления данных будет появляться диалоговое окно, предлагающее из¬ 
менить значение параметра. 


Листинг 9.8. Текст формулы 



іё {?Условие группировки}="С" Ыіеп (СизЬотег .СоипЬгу} 

еізе іё (ЗУсловие группировки}="К” (Шел {СизЬотег .Кедіоп} 
еізе іё (?Условие группировки}=”5" РЬеп {СизЁотег.СіЬу} 


Егііі Рагатеіег РіеИ 


*! 


Рагатеіег РіеИ 
Иатв: 

Рготрііпд іехі: 
Ѵаіие ^рв: 


к-- гругіпѵросж. і 


Впишите букву ^группировка по стране; Рт 


[зЫпд 




0р1іоп5 -*— -:- 

Г ДІІом тикіріе ѵаіиез Беі беіаиіі ѵаіиех | 

(* Оізсшіе ѵаІие($) 

С Папде ѵаІие(«] Г* Аііоѵу есГйіпд оі беіаііі ѵа!ие$ ѵчЬеп 

С йле Рапа? ч-аіоеі Йтеге к тоге іЬап опе ѵаіие . 


ОК | СапсеІ | Неір ' | 


Рис. 9.11. Диалоговое окно Егііі Рагатеіег Ріеігі 
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Рис. 9.12. Диалоговое окно 5е1 Реіаиіі Ѵаіиев 


I В^СгуаіаІ Кер-огі? - [Отчет с группировка*. задаваемой через 


В Не ЕсІІ Ѵіе«ѵ 1тѵ5 Рогтоаі ОаіаЬа» Верст? ѵЛпгіоч Иеір 


о с* •« а;-,® ^ •'& щ в 
I 3\ ЗІѴ 


о ., » .лГ^Г ѳ ш сн <Н|юо* '3; ^ Ж ■> & '& 

і { и XV ; %?. Г - 7. .ѵ ; Д - ш & 2 * ! « ♦' % г;ѵ 


аьвзхездвозгвдкхй 


Оезідп Ргеѵіе** 


Отчет с группировкой. 
АЬи йИаЫ 
АІ 

Аііасе 
• Апкаіз 
Адиііаіпе 
АН 

АисМапсі 

Аиѵеідле 

А2 

Вапдкок 

■ Ѳ«те Моттвгкіе 
Ваумп 

ВС 

ѲеіоНоіігсп*е 

ВвіктКие 

ВеіГю 

8сиідодпе 

Війдеіслѵп 

віидеек 

ВисЬаіетІі 

Вийарей 

СА 

Саію 

СатЪііЙдеіЬііе 

СапІеіЬыу 

Сапіот 

Са«ііе$ 

СеШіе 

. СЬэгорадпвАнЗвппе 
і -СО 

[ Со ОиіЬат 
! • СоиШуАлЫт 


Отчете группировкой, задаваемой через параметры. 


Организация 

АЬиОІюЫ 



Рис. 9.13. Отчет с группированием на основании формулы, зависящей от параметра 


10 Зак. 1021 
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Далее можно приступать к разработке приложения в ОеІрЬі или Ѵіхиаі Вахіс. 
При создании проекта не забывайте подключать файлы СІШеІрЬі.рах или 
С1оЬа132.Ьа$ и СКлѵгар.Ьаз. В проекте создайте экранную форму так, как это 
показано на рис. 9.14 и 9.15. 



\< Обработка отчетов Сгу$*аІ 




.-Условие группировки—*—;--— 


Условие группировки Впишите в поле 
букву: С-груплироека по стране, 

1 . - В'Группироека по региону, 

• $ группировка по городу I 

у 
■ _ 

Выбрать отчет •*" . ‘ " 

Доказать выбранный отчет 


Завершить работу . 




Рис. 9.14. Экранная форма для обработки отчета с параметром в среде ЭеІрЬі 



II *і. Обработка отчетов Сгуііоі 


Условие группировки 


Условие группировки. Впишите в поле 
букву: С-груплироека по стране, 
^-группировка по региону, 

5-группировка по городу 


выбрать отчет 


Показать отчет 


Рис. 9.15. Экранная форма для обработки отчета с параметром в среде ѴізиаІ Вазіс 


Все экранные элементы желательно назвать так, как в табл. 9.4. 

Таблица 9.4. Описание элементов экранного интерфейса приложения 


Тип объекта 

Название 

Текст, видимый на экране 

Кнопка 

ЫлЗеІесШерогІ 

Выбрать отчет 

Кнопка 

ЫпЗйоѵѵВерогі 

Показать отчет 
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Таблица 9.4 (окончание) 


Тип объекта 

Название 

Текст, видимый на экране 

Кнопка 

ЫпСІозе 

Завершить работу 

Поле 

сНРагатРіеІб 

Используется для просмотра текуще¬ 
го значения и задания нового 

Системное диалого¬ 
вое окно, позволяю¬ 
щее выбрать отчет 

НерогізОрепОіаІод 

Настройки данного компонента вы¬ 
полняются по аналогии с предыду¬ 
щими примерами 



Схема 9.3. Блок-схема алгоритма обработки отчета с параметром 
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В предлагаемом примере желательно реализовать алгоритм, который пока¬ 
зан на схеме 9.3. 

Для реализации данного алгоритма необходимо сформировать про¬ 
цедуры так, как это показано в листингах 9.9 и 9.10. Обратите внимание 
на то, что в данных примерах используются дополнительные функции 
РЕОеі№1іРагатеіегРіе1с1 и РЕЗесМіЬРагатеіегРіеІсІ. 


; Листинг 9.9. Реализация процедур просмотра, изменения и передачи 
| параметров в отчет в среде Оеірііі 

ипіъ СКМ_АРІ_Рагат; 

іпЬегіасе 

ивев 

ИіпсЗовдз, Меззадез, ЗузЦЬіІз, ѴагіапЬз, Сіаззез, Сгарігісз, СопЬгоІз, 
Роотз, Ціаіодз, СИЭеІрЬі, ЗЬйСЬгіз; 

Ьуре 

ТігтМаіпРогт = сІааа(ТРогт) 

ОгоирВохІ: ТСгоирВох; 
діРагатРіеІсІ: ТМето; 

ЬаЬеІІ: ТЬаЬеІ; 

ЬЬпЗеІесЬКерогЬ: ТВиСЬоп; 

КерогЬзОреііЛіаІод: ТОрепЦіаІод; 

ЬЬпЗЬоід7Керог(:: ТВиСЬоп; 

ЬЬпСІозе: ТВиЬЬоп; 

ргосеДиге ЬСп5е1ес(:Керог(:С11ск(Зепйег : ТОЬз'есЬ) ; 
ргосесйиге ЬСпЗЬоадКерог(:СІіск(5еп<іег: ТОЬз'есЬ) ; 
ргосесіиге ЬепС1озеС1іск(Зепдег: ТОЪ] есЬ) ; 

ргіѵаЬе 

{ РгіѵаЬе йесІагаЬіопз } 

риЫіс 

С РиЫіс десІагаЬіопз } 

епД; 

ѵаг 

ігшМаіпРогіп: ТігхпМаіпРогт; 
пРгіпЬТоЪ: МогсЗ; 
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ѵРагатІпіо : РЕРагатеЬегРіеІдІпЕо ; 

ітріетѳпі: аріоп 

{$К *. йЕт) 

ргосейиге ТігтпМаіпРогт.ЬЬпЗеІесЬКерогЬСІісМЗепсіег: ТОЬ]есЬ); 

Ьедіп 

Ті КерогЬзОрепІЗіаІод.ЕхесиЬе ТЬеп 
Ведіп 

{Попытка запуска СгузЬаІ Керогбз Ргіпб Епдіпе. 

Если запуск не удался, то выдается сообщение об 
ошибке. } 

ІР РЕОрепЕпдіпе ТЬеп 
Ведіп 

{При корректном запуске Сгузбаі Керогіз РгіпЬ Епдіпе 
выполняется попытка загрузить выбранный отчет . 

Если нё удается загрузить отчет, то выдается сообщение 
об ошибке. } 

пРгіпиоЪ:=РЕОрепРгіп{:аоЪ(РСЬаг (КерогізОрегФіаІод.РіІёЫате)); 
ІР пРгіпЫоЪ=0 ТЬеп 

ЗЬоиМезз аде ('Ошибка открытия отчета') 

Еіге 

Ведіп 

ѵРагатІпРо. зЬгисЬЗіге: = РЕ_512ЕОР_РАКАМЕТЕК_Р ІЕІЛЭ_ІИРО ; 
РЕОѳіЛіЬРагап«е(:егРіе1й(пРгіп(;ПоЬ, 0, ѵРагагпХпіо) ; 
ёЕРагашРіеІд.Ьіпез.ТехЬ:=ѵРагатІпіо.СиггепЬѴаІие; 
ёіРагашРіеІд.ЗеЬРосиз; 

Епа 

Епа 

Епа 

Еіве 

ЗЬомМезз аде ('Ошибка загрузки СгузЬаІ КерогЬ Епдіпе'); 

епа; 

ргосеаиге ТіпгіМаіпРоип.ЪЬпЗЬоадКерогЬСІісМЗепаег: ТОЬ]есЬ) ; 

Ьедіп 

ІР пРгіпЫоЬоО ТЬеп 
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ЗРгРСору (ѵРагатІпРо.СиггепРѴаІие, <ЗРРагатРіе1<З.Ьіпез .ТехР) 
ѵРагатІпРо . зРгисРЗіге:= РЕ_ЗІ2ЕОР_РАКАМЕТЕК._РІЕЬД_ідаО; 
РЕ5еЫ№ЬРагатеРегРіеіа(пРгіпЫоЪ г 0, ѵРагатІпРо) ; 

РЕОиЬриЬТоИіпйоѵ (пРгіпРИ оЬ, 

РСЬаг (КерогЬзОрепГ>іа1од.Рі1еЫате) , 0,0, О, О, 

И8_МАХШІ 2Е+ИЗЛІИШІ 2ЕВОХ+И5_МАХІМІ 2ЕВОХ+ИЗ_ЗУ5МЕШ, 0) ; 

РЕБРагЪРгіпР.Э'оЪ (пРг іп РиТоЪ, ТЕПЕ) ; 

Ела 

ѳзкЗ; 

ргосѳсіиге ТРгтМаіпРогт.ЬРпСІозеС1іск(5епс1ег: ТОІ^есР) ; 

Ьѳдіп 

ІР пРгіпЫоЪоО Ыівп 
Ввдіп 

РЕСІоаеРгіпрдоЫпРгіпРіІоЪ) ; 

РЕСІоаеЕпдіпе; 

Епй; 

Сіозе; 

ела; 


ела. 



Ріт пРгіпРіТоЪ Аз ІпРедег 

Ріт ѵРагатІпРо Аз РЕРагатеРегРіеіаіпРо 

Оіт гезиІР% 

РгіѵаРе ЗиЬ ЪРп5е1есРКерогР_СІіск () 

КерогкзОрепПіаІод.ЗЬовдОреп 
ІР КерогРзОрепПіаІод. Ріі^ате о "" ТНеп 

'Попытка запуска Сгузраі КерогРз РгіпЬ Епдіпе. 

'Если не удалось, то выдается сообщение об ошибке. 

ІР РЕОрепЕпділе ТЬеп 

'При корректном запуске Сгузраі КерогРз РгіпР Епдіпе 
'вьшолняется попытка загрузить выбранный отчет. 

'Если не удается загрузить отчет, то выдается сообщение об ошибке. 
пРгіпЫоЬ = РЕОрепРгіпРЛаЪШерогРзОрепОіаІод. Ріі^ате) 

ІР пРгіпРіТоЪ = 0 ТЬеп 
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МздВох ("Ошибка открытия отчета") 

Еізе 

'Извлечение текущего значения параметра 
ѵРагатІпіо . ЗСгисСЗіге = РЕ_ЗІ2ЕОЕ_РАКАМЕТЕК_ЕІЕЬЦ_ІНРО 
гези11:% = РЕОеЬІіеЬРагатекегРіеІсНпРгіпЫ'оЪ, 0, ѵРагатІпіо) 
сІіРагатРіеІЛ = ѵРагатІпіо.сиггепЬѴаІие 
Епд Іі 
Епй Іі 
Епй Іі 
Епа ЗиЬ 

РгіѵаСе ЗиЬ ЬЫ31іоѵЖерог(:_СІіск () 

Іі пРгіпЫоЬ <> 0 ТЬеп 

'Подстановка нового значения параметра 

Іі а^РагатРіеіа = "С" ТЬеп ѵРагагпІпіо.сиггепСѴаІие = "С" 

Епа іі 

Іі а^РагатРіеіа = "К" ТЬеп ѵРагатіпіо.сиггепСѴаІие = "К” 

Іі діРагатРіеІЛ = "3” ТЬеп ѵРагатІпіо.сиггепЬѴаІие = "3" 

'Передача нового значения параметра в отчет 

гези1С% = РЕЗѳШРЬРагатеЪегЕіеіа(пРгіпЬіІоЪ, 0, ѵРагатІпіо) 

гези1(:% = РЕОиЬриЪТоЗДіпао»; (пРгіпЬіТоЪ, 

КерогСзОрегШіаІод. іл-ІеИате, О, О, О, О, 

М5_МАХШІ2Е + ИЗ_МШІМІ2ЕВОХ + М5_МАХІМІ2ЕВОХ + И5_5У5МЕШ, 0) 
гези1(:% = РЕБЬагЪРгіпЬіТоЬ (пРгіпЫоЬ, Тгие) 

Епа ЗиЬ 

РгіѵаСе ЗиЬ ЬбпС1озе_С1іск() 

Іі пРгіпЫоЬ о 0 ТЬеп 

РЕСІ 08 еРгіпЬ.ІоЪ (пРгіпЫоЬ) 

РЕСІозеЕпдіпе 

Епа іі 
Ш іоаа Ме 
Епа ЗиЬ 

В результате будет получено приложение, позволяющее работать с отчетом, 
который предлагалось создать в начале данного раздела. 

Примечание 

В функциях РЕОеІЫІИРагатеІегРіеісі и РЕЗеІМРРагатеІегРІеІсі в качестве вто¬ 
рого параметра подставляется порядковый номер параметра. Нумерация 
параметров, всегда начинается с 0. Так как в отчете имеется всего лишь один 
параметр, его номер всегда 0. 
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Отчет с группировкой, задаваемой через параметры. 
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Рис. 9.16. Отчет, полученный при установке в качестве значения параметра 

латинского символа С 
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Отчет с группировкой, задаваемой через параметры. 
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Рис. 9.17. Отчет, полученный при установке в качестве значения параметра 

латинского символа Р 
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Отчет с группировкой, задаваемой через параметры. 

Организация Контактное лицо Сѵмма продаж за последний 
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Рис. 9.18. Отчет, полученный при установке в качестве значения параметра 

латинского символа 8 


При изменении значения параметра в поле полученного приложения отчет 
будет выведен на экран так, как это показано на рис. 9.16, 9.17 и 9.18. 


Примечание Л 

Предложенный пример позволяет оценить возможности использования функ¬ 
ций СгузіаІ Перогі АРІ при работе с отчетами, содержащими параметры. Одна¬ 
ко если воспользоваться функциями в полном объеме, можно работать не 
только с заранее известными отчетами, но и выполнять обработку отчетов с 
параметрами любой сложности и с другими дополнительными элементами. Так 
же, используя функции СгузіаІ Керогі АРІ, можно работать с условия фильтра¬ 
ции данных и редактировать их, если это необходимо. 


9.2.4. Работа с различными источниками данных. 
Использование СгузіаІ Рерогі АРІ 

При работе с отчетом часто возникает необходимость переопределить ис¬ 
точник данных, который будет использоваться для формирования результа¬ 
та. Если пользоваться непосредственно СгузіаІ Яерогіз 9, то можно переоп¬ 
ределить источник данных так, как это описано в главе 7. При разработке 
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приложения, вызывающего отчет, хотелось бы иметь механизм, позволяю¬ 
щий выполнять переключение от одного источника к другому, настраивая 
параметры непосредственно в программе. Для выполнения такого рода дей¬ 
ствий существует большой набор функций, позволяющих получить инфор¬ 
мацию об источнике данных, используемом в отчете по умолчанию, и изме¬ 
нить источник и требуемые параметры. К этим функциям относятся 
следующие: 

□ РЕСеІІЧіЬТаЫеТуре — извлекает информацию о библиотеке, используе¬ 
мой для подключения к базе данных; 

□ РЕСе(№ЬТаЫеЬо§ОпІп!о — извлекает информацию об имени сервера 
базы данных, базе данных, имени пользователя и пароле, пароль всегда 
возвращается пустой строкой; 



Схема 9.4. Блок-схема алгоритма, позволяющего менять 
параметры подключения отчета к базе данных из программы 
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□ РЕЬо§Оп8егѵег — передает новые параметры подключения к базе данных 
в отчет; 

□ РЕ8е(1ЧіЬТаЫеЬо§ОпІпГо — определяет список таблиц, к которым необ¬ 
ходимо применить новые параметры подключения. 

Рассмотрим простейший пример работы с этими функциями и реализуем 
приложение, которое работает по алгоритму, представленному на схеме 9.4. 

Примечание Л 

Пример, описанный ниже, предполагает использование различных источников 
данных. При наличии расхождений в структуре данных для разных источников 
этот пример работать не будет, так как для корректировки расхождений потре¬ 
буется использовать еще ряд функций, позволяющих связать новые таблицы и 
поля с имеющимся шаблоном отчета. 

Используя правила, изложенные в предыдущих разделах, создайте новый 
проект в ИеірЬі или Ѵішаі Вазіс. Реализуйте экранную форму, которая пока¬ 
зана на рис. 9.19 и 9.20. 


р. Использование Сгуііаі Керогі ЛР*-дфя 


шшш 


Библиотека связи сБД 
Имя сервера Б Д 
Имя базы данных . 
Имя пользователя . 
Парольполъзоветвля 

Выбрать отчет 


■дЗ 


Показать о 


Завершить работу 


Рис. 9.19. Экранная форма с элементами контроля для просмотра 
и изменения параметров подключения отчета к базе данных в среде ОеІрИІ 


Использование Сгу&Ы ЙероЛ ДРІДІ»: 


Щ - ; Г 

Библиотека связи с БД |* 
Имя сервера БД д Т 
Имябазыданньи 
Имя пользователя Г 
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Пароль пользователя } 

■ ■ ■ -Выбрать отчет..--, 1 Показать отчет I -Завершитъ работу;’ 


Рис. 9.20. Экранная форма с элементами контроля для просмотра 
и изменения параметров подключения отчета к базе данных в среде ѴізиаІ Вазіс 
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Для того чтобы воспользоваться представленными ниже листингами, жела¬ 
тельно объекты в экранной форме определить так, как это описано 
в табл. 9.5. 

Таблица 9.5. Список компонентов, включенных в экранную форму 

Тип объекта Название Текст на экране 


Кнопка 

МпЗеІесІПерогі 

Кнопка 

ЫпЗЬоѵѵПерогі 

Кнопка 

МпСІозе 

Системное диа¬ 
логовое окно, 
позволяющее 
выбрать отчет 

ПерогізОрепОіаІод 

Поле 

сШЬгагу 

Поле 

сИЗегѵег№ше 

Поле 

бГОаІаЬазе 

Поле 

сИІІзегЫате 

Поле 

сіІРазЗѵѵогсІ 

СошЬоВох 

стЬОаІаЬазеУЬгагу 


Выбрать отчет 
Показать отчет 
Завершить работу 

Настройки данного компонента выпол¬ 
няются по аналогии с предыдущими 
примерами 

Описание библиотеки, используемой в 
отчете 

Имя сервера базы данных 
Имя базы данных 
Имя пользователя 
Имя базы данных 

Имя библиотеки, используемой в отче¬ 
те. Выбирается из списка 


У компоненты СошЬоВох заранее необходимо определить список значений: 

□ сгйЬ_р2ЬЬйе.гі11 — Вогіапсі ОаіаЬазе Егщіпе 

□ сггіЪёао.гіІІ — ОАО сіаіа $оигсе$ (Ассеь$) 

□ сг(ІЬ_р2ЬЬ(іе.(ІІІ — Рагасіох 

□ сгйЬ_р2ЬхЬ8е.(Ш — 6ВА5Е, РохРго, Сііррег 

□ сгёЬ_р2ЬЬігѵ.(і11 — Вігіеѵе 

□ сггіЬ_р28ДЬ2.<Ш - ОВ2/2 

□ сгсіЬ_осіЬс.<Ш — ООВС. 5ее Кетагкз Ье1о\ѵ 

□ сгёЪ_огас1е.<Ш — Огасіе 

□ спіЪ_р2ззуЪ10.<і1І — 5уЪа$е 10/11 

Для этого в проекте ОеІрЬі необходимо, установив фокус на компоненту, 
перейти в окно ОЪ^есГ Іпзресіог и сформировать указанный список для 
свойства Иеш8, добавив в начало пустую строку. Кроме этого, необходимо 
установить значение свойства ІГешІпсІех равным 0. Это делается затем, что¬ 
бы в момент запуска приложения выводилась пустая строчка в СошЬоВох. 
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В проекте Ѵізиаі Вазіс для такого же компонента требуется, перейдя в редак¬ 
тор свойств РгорегСіез, заполнить свойство Ьі$1 рекомендуемым списком 
имен, добавив в начало списка пустую строку. Свойство Іпбех должно быть 
равно 0. 

Настроив свойства компоненты ОрепЭіаІое для ОеІрЬі и СоттопОіа1о§ для 
Ѵі$иа1 Ваяіс, так как это предложено в ранее описанных примерах, можно 
приступить к написанию программы. Текст программы показан в листин¬ 
гах 9.11 и 9.12. 

Листинг 9.11. Текст программы в ОеІрЬі, реализующей алгоритм схемы 9.4 

ипіс ігтМаіпЕогт; 

іпЬегТасе 

ивев 

Міпйомз , Меззадез, ЗузТДіІз, ѴагіапРз, Сіаззез, СгарЬісз, СопЬгоІз, 
Еогтз, Біаіодз, СШЭеІрЬі, ЗРйСРгІз; 

Ьуре 

ТМаіп_Еогт = сІавв(ТРогш) 
йСЫЬгагу: ТШіС; 

Й:Е ЗегѵегИате: ТЕЙІ Ь ; 
йВЭаЬаЬазе : ТЕЙІЬ; 
йРЗзегНате : ТЕЙІЬ ; 

ЬйЬеІ1: ТЬаЬеІ; 

ЬаЬе12: ТЬаЬеІ; 

ЬаЬеІЗ: ТЬаЬеІ; 

ЬаЬе14: ТЬаЬеІ; 

ЬаЬеІБ: ТЬаЬеІ; 

ЬЬпЗеІесЬКерогЬ: ТВиЬЬоп; 

ЬРпЗЬоѵ/КерогР: ТВирроп; 

ЬРпСІозе: ТВирроП; 

КерогРзОрепІЗіаІод: ТОрепБіаІод; 
сІіРаззѵгогсІ: ТЕЙІ1:; 
стЬЬаРаЬазеЫЬгагу : ТСотЬоВох; 

ргосейиге ЬЬпЗеІесРКерогРСІісЫЗепйег: ТОЬіесЬ); 
ргоседиге стЬШі:аЬазеЬіЬгагуС1іск(5еп<Зег: ТОЬз'есР) ; 
ргосейиге ЬРп8Ъоіл7Керог1:СІіск(8епсЗег: ТОЬ]есР) ; 
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ргосейиге ЪЫСІозеСІіск (Зепйег: ТОЬз'есЬ}; 

ргіѵаЬе 

{ Ргіѵабе сіесіагабіопз } 

риЫіс 

{ РиЫіс сіесіагабіопз } 

еп<3; 

ѵаг 

Маіп_Рогпг: ТМаіп_Рогт; 
пРг іп Ь іТоЬ: Иогсі; 

ЬЕпдіпе: Вооіеап; 
ѵЬодОпІпіо: РЕЬодОпІпіо; 
ѵЬіЬгагуЫате: РЕТаЫеТуре; 

іпрІехпепЬаЬіоп 

{$К * .сійп} 

{Процедура выбора отчета и загрузки параметров, связанных с базой данных. 
Обрабатывается при нажатии иконки "Выбрать отчет") 

ргосейиге ТМаіп_Ропп.Ы:п5е1ес):Керог(:СІіск(Зепйег: ТОЬэ'есІ:) ; 

Ьѳдіп 

ІЕ КерогбзОрегШіаІод.Ехесибе ТЬеп 
Вѳдіп 

{Попытка запуска Сгузбаі Керогбз РгіпЬ Епдіпе. 

Если запуск не удался, то выдается сообщение об 
ошибке .} 

ЬЕпдіпе : = РЕррепЕпдіпѳ г 
ІЕ ЬЕпдіпе ТЬеп 
Ведіп 

{При корректном запуске Сгузбаі Керогбз Ргіпб Епдіпе 
выполняется попытка загрузить выбранный отчет. 

Если не удается загрузить отчет, то выдается сообщение 
об ошибке .} 

пРгіпб > ТоЬ:=РЕОрепРгіп(:іЭ'оЪ(РСЬаг (КерогЬзОрепБіаІод.Ріі^ате) ) 

ХЕ пРгіпбіТоЬ=0 ТЬеп 

ЗЬоадМеззаде ('Ошибка открытия отчета') 

Еіае 


Ведіп 
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{Получение информации о библиотеке, 
используемой для подключения к базе данных} 

ѵЬіЬгагуНате.ЗбгисбЗіге := РЕ_ЗІ2Е0Р_ТАВЬЕ_ТУРЕ; 
РЕСеШЪМаЫеТуре (пРгіпДД'оЪ, 0, ѵі,іЬгагуНаше) ; 
стЬОабаЬазеЫЬгагу. ТехЬ := ѵЬіЬгагуЫате.ВЬШате; 
стЬВаЬаЬазеЬіЬгагуСІіск(ЗеІЕ); 

{Получение информации о сервере, 
базе данных, имени пользователя и пароле} 

ѵЬодОпІпіо . ЗбгисбЗіге := РЕ_ЗІ2Е0Р_Ь0С0Н_ЮТ'0; 
РЕОеШДЬТаЫеІіодОпХпРо (пРгіпЫЪЪ, 0, ѵЬодОпІпіо} ; 
(ЗіЗегѵегМате.Техб := ѵЬодОпІпіо.ЗегѵегЫате; 
(ЗЙЭабаЪазе . Техб := ѵЬодОпІпіо.ВабаЬазеЫате; 
бГизегМате .Техб := ѵЬодОпІпіо.ТІзегІсі; 
діРаззѵгогсІ. Техб := ѵЬодОпІпіо. Раззѵгогсі; 

ЕпЙ 

Епд 

Епд 

Еіве 

ЗЬоілМеззаде('Ошибка загрузки Сгузбаі КерогЬ Епдіпе') 

ѳпй; 

{Процедура изменения библиотеки связи с базой данных - Применяется при 
выборе значения из СатЬоВох} 

ргосебиге ТМаіп_Рот.стЬВа(:аЪазеІ,іЬгагуС1іс'к(5еп<іег: ТОЬоесЬ) ; 

ѵаг 

і: Іпбедег; 

Ьѳдіп 

і := 0; 

ѵДііІе (і < стЬВабаЬазеЫЬгагу.ІДегпз.СоипІ:) апб 
(стЬВабаЪазеЬіЪгагу.Ібетз[і] о стЬПабаЬазеЬіЬгагу.Техб) йо 

іпс(і); 

Саге і оі 

0: й€ЬіЬгагу.Тех(::='База данных не выбрана'; 

1: сІіЬіЪгагу.ТехІ:: = 'Вог1апс1 БаЬаЪазе Епдіпе'; 

2: йіЬіЬгагу.Тех(:;='ШО Йаба зоигсез (Ассезз} ' ; 

3 : йіЫЬгагу. Техб: = ' Рагайох' ; 

4; (ЗіІ,іЪгагу.Тех1;: = '<ІВА8Е, РохРго, Сііррег'; 

5: йіЬіЬгагу.Техб: = 'ВДгіеѵе'; 

6: йіЬіЬгагу.ТехІ:: = 'ВВ2/2'; 
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7: ЫЬЫЪгагу . ТехЬ : = ’ ОБВС ' ; 

8: сИіЬіЪгагу.ТехЬ: = 'Огасіе'; 

9: дЬЫЪгагу . ТехЬ : = ' ЗуЪазе 10/11'; 
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Епй; 

епй; 

{Процедура запуска отчета с новыми параметрами подключения к базе данных. 
Применяется при нажатии кнопки "Показать отчет") 

ргосесіиге ТМаіп_Рогт. ЬЬпЗЬоадКерогЬСІіск (Зепйег: ТОЪ^'есЬ) ; 

Ьѳдіп 

{Изменение информации о параметрах подключения 
к базе данных) 

ѵЬодОпІпЬо . ЗЬгисЬЗіге := РЕ_ЗІ2ЮР_ЬССОЫ_ШРО; 

ЗЬгРСору (ѵЬодОпІпіо . ЗегѵегЫаше, йІЗегѵегЫагпе.ТехЬ); 

ЗЬгРСору (ѵЬодОпІпЬо. ОаЬаЪазеЫате, сіЬБаЬаЪазе. ТехЬ) ; 

ЗбгРСору (ѵЬодОпІпіо .ИзегЮ, дШзегЫате . ТехЬ) ; 

ЗЬгРСору(ѵЬодОпІпіо.РаззадогсЗ, йЬРаззѵгогй.ТехЬ); 

{Передача параметров подключения к базе данных в отчет) 

Ті пор РЕііОдОпБѳгѵѳг (РСЬаг {сгоЬОаЬаЬазеЬіЬгагу .ТехЬ), ѵЬодОпІпЬо) 

РЬеп 

ЗЪоШеззаде ('Ошибка передачи параметров соединения 
с базой данных'); 

{Привязка таблиц в отчете к указанным параметрам. 

Вызов данной процедуры обязателен.) 

ІЕ поЬ РЕЗеШРЬТаЫѳІіодОпІпіо (пРгіпЬИоЬ, 0, ѵЬодОпІпЬо, ТКЦЕ) Ыіеп 

ЗЬомМеззаде ('Ошибка передачи параметров соединения 
с базой данных'); 

РЕОиРриРТоМіпсІоѵ/ (пРгіпЬСГоЬ, 

РСЪаг (КерогЬзОрегіОіаІод.ЕіІеНате) , 0,0,О,О, 
И5_МАХІМІ2Е+Н5_МітМІ2ШОХ+Н5_МАХІМІ2ЕВОХ+ИЗ_8У8№Ш, 0) ; 

РЕБрагрРгіпРСГоЬ (пРгіпЬОоЬ, ТКЦЕ) ; 

епсі,- 


{Процедура завершения работы отчета) 

ргосейиге ТМаіп_Рогш.ЬЬпС1озеСІіск(Зепсіег : ТОЪдесЬ); 

Ьедіп 

ІЕ (ЬЕпдіпе=ТКЦЕ) ТЬеп 
Вѳдіп 

Іі пРгіпЬЛоЪоО ТЬеп 

РЕСІозеРгіпЬіТоЪ (пРгіпЬЦоЬ) ; 
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РЕСІовеЕпдіпе ; 

Епд; 

Сіозе; 

епд; 

вид. 

Листинг 9.12. Текст программы в ѴізиаІ Вазіс, реализующей алгоритм схемы 9.4 

Еіт гези1Ь% 

Біт пРгіпЬЛоЬ Аз ІпЬедег 
Віт ЬЕпдіпе Аз Вооіеап 
Оіт ѵЬодОпІпіо Аз РЕЬодОпІпіо 
Оіт ѵЬіЬгагуЫате Аз РЕТаЫеТуре 

'Процедура выбора отчета и загрузки параметров, связанных с базой данных. 
' Применяется при нажатии иконки "Выбрать отчет” . 

РгіѵаЬе ЗиЬ ЬЬпЗе1есІ;КерогІ:_С1іск () 

КерогбзОрепПіаІод.ЗЬомОреп 
Хі КерогЬзОрегіОіаІод. ФПеИате <> ТЬеп 

'Попытка запуска СгузіаІ КерогЬз Ргіпб Епдіпе. 

' Если не удалось, то выдается сообщение об ошибке . 

ЬЕпдіпе = РЕОрепЕпдіпѳ 

Іі ЬЕпдіпе ТЬеп 

'При корректном запуске Сгузбаі КерогЬз РгіпЬ Епдіпе 
'выполняется попытка загрузить выбранный отчет. 

'Если не удается загрузить отчет, то выдается сообщение об ошибке. 
пРгіпЫоЬ = РЕОрѳпРгіпЬіТоЪШерогЬзОрепІЭіаІод. ііІеЫате) 

Іі пРгіпЫоЬ = 0 ТЬеп 

МздВох ("Ошибка открытия отчета") 

Еізе 

'Получение информации о библиотеке, 

'используемой для подключения к базе данных 

ѵЬіЬгагуЫате . ЗЬгисЬЗіге = РЕ_ЗІ2Е0Е_ТАВЬЕ_ТУРЕ 
гези1б% = РЕОеШЬЬТаЫеТуре (пРгіпЫЪЬ, 0, ѵЫЬгагуНате} 
стЬБабаЬазеЬіЬгагу. ІЬегп(0} = ѵЬіЬгагуЫате .ЕЬШате 
сгпЬОаЬаЬазеЬіЬгагу_СІіск (0) 

'Получение информации о сервере, 

'базе данных, имени пользователя и пароле 

ѵЬодОпІпіо . ЗЬгисЬЗіге = РЕ_5І2Е0Р_І,00Ш_ЮТ , 0 
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гези1і% = РЕСеіМіЬТаЫеЬодОпІпіо (пРгіпЬ.ТоЬ, 0, ѵЬодОпІпіо) 

сИЗегѵегИате = ѴЬодОпІпіо.ЗегѵегМате 

сЮЭаіаЪазе = ѴЬодОпІпіо.ВаЬаЬазеИате 

йШзегЫате = ѴЬодОпІпіо .ЬГзегІЬ 

сІіРаззѵгогсі = ѵЬодОпІпіо.Раззмогй 

Епа Іі 
Еізе 

МздВох ("Ошибка запуска Ргіпі Епдіпе") 

Епй Іі 
Епй Іі 

Епсі ЗиЪ 

'Процедура запуска отчета с новыми параметрами подключения к базе данных. 
'Применяется при нажатии кнопки "Показать отчет". 

Ргіѵаіе ЗиЬ ЬбпЗЬоѵ/КерогІ:_С1іск () 

'Изменение информации о параметрах подключения 
'к базе данных 

ѵЬодОпІпіо.ЗігисіЗіге = РЕ_5І2ЕОР_ЬОСОМ_ШРО 

ѵЬодОпІпіо.ЗегѵегМате = сІіЗегѵегМате + 5Ьгіпд(128 - 
Ьеп(сІіЗегѵегМате), СЪг$(0)) 

ѴЬодОпІпіо.БаіаЪазеМате = сЗНЗаіаЪазе + 5Ьгіпд(128 - 
Ьеп ((ЗіШіаЪазе) , СЬг$(0)) 

ѵЬодОпІпіо.ПзегІБ = діИзегМате + 5ігіпд(128 - 
Ьеп (аШзегИате) , СЬг$(0)) 

ѴЬодОпІпіо. РаззѵгогсЗ = сЗіРаззѵгогй + 5Ыіпд(128 - 
Ьеп(ЗіРаззѵгогсІ), СЬг$(0)) 

'Передача параметров подключения к базе данных в отчет 
гези1і% = РЕІюдОпЗегѵег (стЬРаЬаЬазеЫЬгагу. ІЬет (0) , ѴЬодОпІпіо) 

Іі гези1і% = 0 ТЬеп 

МздВох ("Ошибка передачи параметров соединения с базой данных") 
Епсі Іі 

'Привязка таблиц в отчете к указанным параметрам. 

'Вызов данной процедуры обязателен. 

гези1і% = РЕБѳЫТРЪТаЪІеЬодОпІпіо(пРгіпЬИоЬ, 0, ѴЬодОпІпіо, Тгие) 

Іі гези1і% = 0 ТЪеп 

МздВох ("Ошибка передачи параметров соединения с базой данных") 
ЕпсЗ Іі 
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гезиІ5% = РЕОиРриРТоМіпдоѵ; (пРгіпЫоЪ, 

КерогРз0репІ)іа1од.5і1ёМате, О, О, О, О, 

И8_МАХІМІ2Е + И5_МЮТМІ2ЕВОХ + ИЗ_МАХІМІ2ЕВОХ + ИЗ_5УЗМЕШ, 0) 
гезиІ5% = РЕЗеагрРгіпРіТоЬ(пРгіпЫоЪ, Тгие) 

Епд ЗиЪ 

'Процедура изменения библиотеки связи с базой данных. 

'Применяется при выборе значения из СатЪоВох 

РгіѵаРе ЗиЪ стЬОаЬаЪазеЬіЪгагу_С1іск(Іпдех Аз ІпРедег) 

ЗеІесР Сазе стЬПаЬаЪазеПіЪгагу . ІРет(О) 

Сазе д5ЫЪгагу = "База данных не выбрана" 

Сазе "сгдЪ_р2ЪЪде.д11": д5ЬіЪгагу = “Вогіапд БаРаЪазе Епдіпе" 

Сазе "сгдЪ_дао.д11“: д5ЬіЪгагу = "БАО дара зоигсез (Ассезз) “ 

Сазе “сгдЪ_р2ЪЪде.д11": д5ЫЪгагу = "Рагадох" 

Сазе “сгдЪ_р2ЪхЪзе.д11": д5ЫЪгагу = "дВАЗЕ, ЕохРго, Сііррег" 

Сазе "сгдЬ_р2ЪЪРгѵ.д11'': д5ЫЪгагу = "ВРгіеѵе" 

Сазе "сгдЪ_р2здЪ2 .діі": д5ЫЪгагу = "БВ2/2” 

Сазе "сгдЪ_одЪс.д11'': д5ЫЪгагу = "ОБВС” 

Сазе "сгдЪ_огас1е.д11": д5ЬіЪгагу = "Огасіе" 

Сазе "сгдЪ_р2ззуЫ0 .діі": д5ЫЪгагу = "ЗуЪазе 10/11" 

Епд ЗеІесР 

Епд ЗиЪ 

'Процедура завершения работы отчета. 

РгіѵаРе ЗиЪ Ъ5пСІозе_С1іск() 

II ЪЕпдіпе ТЪеп 

15 пРгіпЫоЪ <> 0 ТЪеп 

РЕСІозеРгіпРіГоЪ (пРгіпЫоЪ) 

Епд 15 

РЕСІозеЕпдіпѳ 

Епд 15 
Шіоад Ме 
Епд ЗиЪ 

После отладки и компиляции данного программного кода можно запустить 
приложение и, выбрав какой-либо отчет, увидеть информацию о парамет¬ 
рах связи отчета с базой данных так, как это показано на рис. 9.21 
и 9.22. 
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Рис. 9.21. Программа ОеІрНі для работы 
с параметрами подключения к базе данных 


Использование Сгуъіаі КёрогЦ 


щ-. 7 ’ ■ г7: _ ]□) х 

[ОАО баіа $ошсе$ (Ассе$$) 


Библиотека связи с БД ІсібЬдЗао.сІІІ 
Имя сервера БД 
Имя базы данных 

Имя пользователя 
Пароль пользователя 




ВЛРюдгат Не$\Сіу$ІаІ Весі$юп$\Оу$*аІ ВероЛв З‘\5а 
ЮіЧРюдгат ГіІе$\ОуіаІ Ьесі$іоге\С[у$Ьа1Верогіз 9\5а 


Выбрать отчет 


Показать отчет 


Завершить работу 


Рис. 9.22. Программа ѴізиаІ Вазіс для работы 
с параметрами подключения к базе данных 


Изменив параметры в полях экранной формы, можно вывести выбранный 
отчет на просмотр, нажав кнопки Показать отчет. Как уже было сказано 
ранее, структура источника данных, для которого задаются новые парамет¬ 
ры, должна совпадать со структурой того источника, на основании которого 
строился отчет. Иначе на экран ничего не будет выведено. Для того чтобы 
усложнить данные примеры и получить больше возможностей для работы 
с параметрами подключения отчета к базе данных, необходимо пользоваться 
полным спектром функций, описанных в Приложении 1. 
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9.3. Использование компонент АсІіѵеХ 


Помимо возможности, предоставленной СгузтІ Верой Ргіпі Еп§іпе АРІ, су¬ 
ществуют другие подходы к реализации приложений, работающих с отчета¬ 
ми СгузіаІ Верой 9. Одним из таких механизмов является возможность ис¬ 
пользования АсііѵеХ компонент. В СгузіаІ Веройз версии 8.5 и младше 
присутствовал компонент, который можно было использовать в любых 
средствах разработки приложений, позволяющих работать с АсііѵеХ компо¬ 
нентами. Этот компонент использует функции из библиотеки СгузіаІ Верой 
Ргіпі Еп§іпе АРІ. Но, к сожалению, его функциональное наполнение не ме¬ 
нялось со времен СгузіаІ Веройз версии 5.Х. Поэтому большое количество 
функций, добавленных в СгузіаІ Веройз старших версий, не работают в дан¬ 
ной компоненте. Начиная с СгузіаІ Веройз 9.Х данный компонент более не 
входит в поставку. Вместо него предлагается использовать СгузіаІ Верой 
Эезщпег Сотропепі. Данные компоненты позволяют не только выполнять 
интеграцию отчетов СгузіаІ Веройз 9 в приложения, но и создавать свою 
собственную оболочку, дающую возможность создавать новые отчеты. 


Примечание 


Приобретая пакет СгузіаІ Веройз 9.0 Оеѵеіорег или Абѵапсеб, вы получаете 
возможность выполнять разработку приложений с применением компонентов 
СгузіаІ Верой Оезідпег Сотропепіз. Однако использовать разработанное при¬ 
ложение можно будет только на том компьютере, где выполнялась разработка. 
Для установки приложения на другие компьютеры потребуется дополнительная 
лицензия, которая меняется в зависимости от потребностей. За уточнениями, 
относящимися к лицензированию, необходимо обращаться непосредственно 
в компанию СгузіаІ Оесізіопз. 


Использовать СгузіаІ Верой Оезідпег Сотропепіз можно только при разработке 
приложений с помощью ѴізиаІ Вазіс или ѴізиаІ С++. 


Для того чтобы понять, как использовать данный компонент, создадим при¬ 
ложение в ѴізиаІ Вазіс. Чтобы обеспечить использование в приложении 
компонент СгузіаІ Верой Эезщпег Сотропепіз, необходимо выполнить сле¬ 
дующие действия. 

1. В ѴізиаІ Вазіс создается стандартный проект. 

2. Выбирается команда меню Рпуесі | Агіё СгузіаІ Керогіз 9. 

3. В появившемся диалоговом окне, которое показано на рис. 9.23, выбира¬ 
ется вариант работы с отчетом по аналогии с СгузіаІ Веройз 9: 

• 1)зіп§ ТЬе Верой Ехрей — использовать эксперт; 

• Аз а Віапк Верой — использовать настраиваемый самостоятельно 
бланк отчета; 

• Ргот ап Ехізііп§ Верой — использовать существующий отчет. 
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4. Для ознакомления выбирается вариант Ргот ап Ехізііпё Керогі. При 
этом, после выбора отчета, появляется диалоговое окно, показанное 
на рис. 9.24. В этом окне предлагается установить параметры изменения 
проекта. Первоначально желательно в этом диалоге ничего не менять. 

5. Проект изменится автоматически. В него будут добавлены компоненты, 
позволяющие отредактировать отчет так же, как это делается в Сгузіаі 
Керогіз 9, и новая форма, содержащая компоненту СВѴіе\ѵег. Эти изме¬ 
нения в проекте показаны на рис. 9.25 и 9.26. 

6. Далее требуется изменить название добавленной в проект формы Рогш2 
на другое, предположим, ГгтКероііѴіе\ѵег, и описать метод, относящийся 
к загрузке формы так, как это показано в листинге 9.13. 

^ Примечание ^ 

При использовании предложенного алгоритма, весь программный код будет 
сформирован автоматически. После его проверки можно запускать получив¬ 
шееся приложение. 


ШШ8Ш 


Сгеаіе а Меи Оу$1аГНеро(( ОоситепІ 
, ** Щаід ІНѳ ВероК Ехрегі 

[~~Ч Г 4 А? а’БІапк Верга! 

.О' Ріот ап ЕшЬпд Вероіі 



ОК | • .ЛеІр : 


Рис. 9.23. Окно СгузіаІ Нероіі СаІІегу 
Использование Сгузіаі Нероіі Оезідпег Сотропепіз 
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ІСгуіІаІ Керогі Ехрегі 


ТЬ* ехраГсап агіс а ‘оі.т. Іо >.ге ріаіесІиЫсЬ ѵѵіі! Ье »$ес (о 
ріеѵів'ЛІЬе іероіі аі іипйпе. 


Роуои мапі іНеекрегІ (о асИ а (огт сопІаіпіпдТЬе СгузіаІ 
Верогі Ѵіеиег сопігоі? ■ 


ѴоиМ уои Ііке 1Ьё ехрегііо гпосіііу іНе ріорсі рюреіЙв? Іо 
. 8Й ІНІз йігп а$,1Ье зіагіир оЬІесІ? , 


Г" 5кір іЫ$ $сгееі іп іНе іиіиіе. 


Рис. 9.24. Окно настройки параметров изменения проекта. 
Использование СгузіаІ Керогі Оезідпег Сотропепіз 
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Рис. 9.25. Дополнение, внесенное в проект. Среда редактирования отчета 
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Рис. 9.26. Экранная форма, содержащая компоненту СгувіаІ Ѵіеѵѵег 


Листинг 9.13. Проект, относящийся к загрузке экранной формы с компонентом ; 
просмотра отчета. Данный текст формируется автоматически т'й|й : і 


РгіѵаРе 5иЬ Рогт_Ьоас1() 

Зсгееп.МоизеРоіпРег = ѵЪНоигдІазз 
СКѴіеадегЭІ .КерогРЗоигсе = КерогР 
СКѴіеадегЭІ.ѴіемКерогР 
Зсгееп.МоизеРоіпРег = ѵЬОеіаиІР 
Епд. ЗиЬ 


В результате после запуска получившегося приложения на экран выводится 
экранная форма с окном просмотра отчета (рис. 9.27). 
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Рис. 9.27. Результат использования СгузіаІ Верогі Резідпег Сотропепіз 

Предложенный механизм использования этих компонентов является самым 

простым. Как было сказано ранее, существует большое количество способов 

использования данных компонентов. Но даже для такого варианта прило¬ 
жения есть еще много методов, позволяющих управлять окном просмотра: 

□ ВНрІауВаск^гоишІЕсІйе — механизм отображения или скрытия края стра¬ 
ницы; 

□ БіярІауВопІег — показывать механизм отображения или скрытия рамок; 

□ БіарІауСгоирТгее — механизм отображения или скрытия дерева групп; 

□ БізрІауТаЬз — механизм отображения или скрытия вкладок; 

□ БізрІауТооІЬаг — механизм отображения или скрытия панели инструментов; 

□ ЕпаЫеАпішабопСігІ — механизм, обеспечивающий доступ к элементам 
анимации; 

□ ЕпаЫеС1о$еВиІЮп — механизм, обеспечивающий доступ к кнопке закры¬ 
тия отчета; 

□ ЕпаЫеБгі1Юо\ѵп — механизм, разрешающий выполнять специальную вы¬ 
борку в отчете; 
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□ ЕпаЫеЕхрогіВийоп — механизм, обеспечивающий доступ к кнопке экс¬ 
порта; 

□ ЕпаЫеСгоирТгее — механизм, обеспечивающий доступ к кнопке показа 
дерева групп; 

□ ЕпаЫеНеІрВиМоп — механизм, обеспечивающий доступ к кнопке помощи; 

□ ЕпаЫе7Чаѵі§аІіопСопйго1§ — механизм, обеспечивающий доступ к кнопкам 
навигации; 

□ ЕпаЫеРорирМепи — механизм, обеспечивающий доступ к выпадающему 
меню; 

□ ЕпаЫеРгіпіВийоп — механизм, обеспечивающий доступ к кнопке печати; 

□ ЕпаЫеРго^гехчСопІгоІ — механизм, обеспечивающий отображение инди¬ 
катора прогресса; 

□ ЕпаЫеКеГгекЬВийоп — механизм, обеспечивающий доступ к кнопке об¬ 
новления; 

□ ЕпаЫеЗеагсЬСопігоІ — механизм, обеспечивающий доступ к элементам 
поиска; 

□ ЕпаЫеЗеагсЬЕхрегГВииоп — механизм, обеспечивающий доступ к кнопке 
вызова эксперта поиска; 

□ ЕпаЫе8е1есІЕхрегІВи«оп — механизм, обеспечивающий доступ к кнопке 
вызова диалогового окна настройки фильтрации данных в отчете; 

□ ЕпаЫеЗіорВіШоп — механизм, обеспечивающий доступ к кнопке пре¬ 
кращения загрузки данных; 

□ ЕпаЫеТооІЬаг — механизм, обеспечивающий доступ к кнопке в панели 
инструментов; 

□ ЕпаЫе/оотСопІгоІ — механизм, обеспечивающий доступ к элементам 
управления размерами отчета. 

О более развитых возможностях компонентов Сгузіаі КероЛ Ое$і§пег Сош- 
ропепіз можно узнать из документации Сгузіаі Оеѵеіорегз Сиібе, которая по¬ 
ставляется совместно в СгузЫ Керогіз 9.0 Оеѵеіорег или Абѵапсеб. 

9.4. Использование компонентов для ЭеІрЫ 

Для удобства разработчиков, использующих ОеІрЬі в качестве среды разработки 
приложений, работающих с отчетами Сгузіаі Керогй 9, предусмотрен компо¬ 
нент, который поставляется с Сіузіаі КероНз 9.0 Оеѵеіорег или Абѵапсеб. В мо¬ 
мент установки Сгузсаі Керогіз 9 можно выбрать требуемый компонент, он будет 
скопирован в каталог ..\Рго§гат Рі1е5\Сгу5іа1 Оесізіопз\Сгу5Іа1 Керогй 9\$атр1ез\ 
Еп\Собе\Ое1рНі\сг85ѵс1.ехе. При запуске данного приложения будет выполнен 
процесс установки пакетов, требуемых для работы данного компонента в ОеІрЬі. 
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^ Примечание 

Как видно из названия файла, данный пакет не изменял свои свойства с СгузіаІ 
КероПз версии 8.5. 


В момент установки необходимо следовать рекомендациям программы уста¬ 
новки. Программа автоматически определит версию ОеІрЬі и предложит 
каталог для записи нужных пакетов. При необходимости некоторые парамет¬ 
ры можно изменить. По завершении установки в палитре инструментов Оеі 


рЫ, на вкладке Оаіа Ассехх, появятся дополнительные компоненты 


О 


I. Расшифрованное наименование данных компонентов: 


□ СКРЕ — Сгухіаі К.ерогі Ргіпі Еп§іпе; 

□ СКРЕ Б8 — Сгухіаі КероП Ргіпі Еп§іпе Баіа Зоигсе. 

Названия указывают на то, что данные компоненты используют для своей 
работы функции Сгухіаі Кероп Ргіпі Епфпе АРІ, некоторые из которых опи¬ 
саны в данной главе в разд. 9.2, а полный список этих функций представлен 
в Приложении 1 и Приложении 2. 


Чтобы убедиться в работоспособности данного компонента, имеет смысл 
выполнить простейший тест. Открыв новый проект, создайте экранную 
форму так, как это показано на рис. 9.28. 


Сгу«ІаІ Керр 




I Работа с отчетами .СДОаІ 
В ерогі$, используя 


Показать отчет 


Рис. 9.28. Экранная форма, содержащая компонент 
для работы с отчетами СгузіаІ НероПз 


Настройте компонент ОрепОіа1о§ так, как это предложено в ранее рассмот¬ 
ренных примерах. Переименуйте компонент СКРЕ1 в СгухіаІКріСотропепі. 
Установите у кнопки свойство Кате — Ып5Ьо\ѵКерогі и напишите про¬ 
стейший программный код, показанный в листинге 9.14. 


щтщттшттт 


щая з апу ст 

;:Отче^ Испальзова^іі|і^:компонентаСКРЕ ' ' 


ргоседиге ТРогтІ .ЬСп8ЬошКерог(:С1іск(5епйег: ТОЬз'есС); 

Ьедіп 

Хі. КерогСзОрепОіаІод.ЕхесиСе ТЬеп 
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Ведіп 

СгуаЪаІКрЪСопчэопегЛ .КерогШате := КерогРзОрегШіаІод.КіІеНате; 

СгуеЬаІКрЬСопропепЬ. ЕхесиРе; 

ЕПЙ 


ѳпй; 


Запустив данную программу на выполнение и выбрав любой доступный от¬ 
чет, вы увидите его на экране в окне просмотра. Приведенный пример по¬ 
казывает, что использование компонента в Оеірйі намного упрощает разра¬ 
ботку приложений, применяющих отчеты, созданные в Сгузіаі Яерогіз 9. Так 
как компоненты для ПеІрЬі созданы с использованием функций Сгузіаі Яе- 
рогі Ргіпі Еп§іпе АРІ, разработчики получают полный набор возможностей 
по работе с отчетами. 

9.5. Дополнительные варианты интеграции 
отчетов СгувіаІ Верогіз в приложения 

Помимо описанных в предыдущих разделах возможностей интеграции отче¬ 
тов Сгуыаі ЯероДз 9 в приложения, существует новый механизм, предназна¬ 
ченный для использования отчетов из .Іаѵа-приложений. По аналогии 
с компонентами Сгузіаі ЯЭС разработана компонента Сгузіаі Кероп Ѵіеѵѵег 
Веап. Этот компонент, так же как компоненты Сгузіаі ЯОС, можно доба¬ 
вить в приложение, создаваемое с помощью средств визуального програм¬ 
мирования .Іаѵа. К сожалению, он работает некорректно в наиболее распро¬ 
страненных средствах .Іаѵа-программирования, таких как Вогіапб ІВиіІсіег, 
Огасіе .Шеѵеіорег и т. п. Для его работы необходимо установить пакет Іаѵа 2 
ЗЭК. 1.1, который можно бесплатно загрузить с \ѴеЬ-сайта фирмы- 
изготовителя Зип Місгозузіетз. Для работы данного компонента необходимо 
наличие \ѴеЬ-сервера, чтобы обеспечить обращение к отчету так же, как это 
делается при обращении к любой \ѴеЬ-странице. Результатом разработки 
приложения с использованием данного компонента является Іаѵа-апплет, на 
который устанавливается ссылка из НТМЬ-страницы. Описание и пример 
интеграции отчетов Сгузіаі Яерогіз в .Іаѵа-апплеты представлены в докумен¬ 
тации разработчика Сгузіаі Яеройз Эеѵеіорегз Сиібе. 


Заключение 

Материал данной главы не претендует на полноту и идеальность. Однако 
автор надеется, что в предоставленном материале содержится информация, 
которая позволит опытным разработчикам быстро разобраться с имеющи¬ 
мися возможностями и использовать их в своей работе, а новички получат 
дополнительные знания, которые пригодятся им в дальнейшем. 




Приложение 1 



Список функций СгузіаІ Перогі Ргіпі 
Епдіпе АРІ 

В Приложении 1 и Приложении 2 представлен список функций и определяе¬ 
мых пользователем типов данных, которые иногда именуются как записи 
или структуры. Все описания даны применительно к языку ОЪ)есІ Рахсаі 
системы ОеІрЬі. Однако, используя предложенную информацию, можно 
реализовать работу с функциями в любом средстве разработки, поддержи¬ 
вающем использование функций АРІ. 


(_ Замечание _^ 

В документации, которая поставляется совместно с Сгузіаі Керойз 9 и относит¬ 
ся к разделу Сгузіаі 1_едасу ЗЭК, можно найти описание функций и типов для 
МісгозоЙ ѴізиаІ Вазіс и С++. В этой документации присутствует также большое 
количество примеров, которые будут полезны разработчикам. 


Функция РЕАсМРагатееегСиггепекапде — добавляет значения, соответст¬ 
вующие требуемому диапазону, в указанное поле-параметр отчета. 

( Замечание ) 

В данный момент поля такого типа не поддерживаются в ѴѴеЬ Ѵіеѵѵег. 

ргосейиге РЕАсМРагатеСегСиггепСКапде( 
ргіпСДоЬ: втаіііпе; 
сопзС рагатеСегРіеІдЦаше : РСІіаг; 
сопзС герогШате: РСЬаг; 
ѵаг гапдеЗСагС: РЕѴаІиеІп^о ; 
ѵаг гапдеЕпй: РЕѴа1иеІп€о ; 
гапдеіпго : втаІІіпС ; 

): ВООЬ зСйсаІІ; 
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Приложение 1 




Параметры функции 

Описание параметров 

ргіпРіТоЪ 

Номер отчета, в который необходимо добавить значение 
параметра диапазона 

рагате С егРіе1 сШаше 

Строка, содержащая имя поля параметра 

герогСЫате 

Строка, содержащая имя отчета 

гапдеЗСагР 

Запись РЕѴаІиеіпіо, которая содержит значение ниж¬ 
ней границы диапазона 

гапдеЕпсі 

Запись РЕѴаІиеіп^о, которая содержит значение верх¬ 
ней границы диапазона 

гапдеіпіо 

Значение, которое указывает на необходимость учета 
верхней или нижней границы. Можно использовать ком¬ 
бинацию констант: 

Константа ре_кі_™сшоеіірреквоші> 

Значение 1 

Константа ре_кі_інсшлецомеквоцж> 

Значение 2 

Константа ре„кі_юпрреквоцж> 

Значение 4 

Константа ре_кі_шьомеквошг> 

Значение 8 


Возвращаемые значения: 

□ ТИШЕ — если вызов удачен; 

□ РАЬБЕ — если вызов неудачен. 


Функция РЕАцарагатееегСиггепеѵаіие — добавляет значение параметра в 
указанное поле параметр отчета. 


Замечание 


В данный момент поля такого типа не поддерживаются в ѴѴеЬ Ѵіеѵѵег. 


ргосесіиге РЕАббРагатеСегСиггепОѴаІие ( 
ргіпЫоЪ: шпаІІігЛ; 
сопзР рагатеРегЕіеІйИате: РСЬаг; 
сопзС герогШате: РСЬаг; 
ѵаг сиггепСѴаІие: РЕѴаІиеІпСо 
): ВООЬ зЬйсаІІ; 
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Параметры функции 

Описание параметров 

ргіпедоЬ 

рагатеЬегЕ’іеШЫате 

герогШате 

сиггепЬѴаІие 

Номер отчета, в который необходимо добавить значение 
параметра 

Строка, содержащая имя поля параметра 

Строка, содержащая имя отчета 

Запись РЕѴаІиеІпЪэ, которая содержит добавляемое в поле 
значение параметра 

Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЕ5Е — если вызов неудачен. 

Функция РЕАсісіРагатееегОеігаиіъѵаіие — добавляет значение в группу зна¬ 
чений по умолчанию для указанного параметра в отчете. 

ргосейиге РЕАсісіРагатеЬегОеіаиіеѴаІие ( 
ргіпЬДоЬ: втаіііпе ; 
сопзЬ рагатеЬегРіеІсДІаіпе: РСЗіаг; 
сопзС герогШате : РСЪаг; 

ѵаг ѵаІиеІпГо: РЕѴаІиеІпТо 

) : ВООЬ зЬсЗсаІІ; 

Параметры функции 

Описание параметров 

ргіпЬДоЪ 

рагатеЬегРіеІсЩате 

герогЬЫаше 

ѵаІиеІпГо 

Номер отчета, в который необходимо добавить значение 
параметра по умолчанию 

Строка, содержащая имя поля параметра 

Строка, содержащая имя отчета 

Запись РЕѴаІиеІЩо, которая содержит добавляемое по 
умолчанию значение 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСапсеіРгіпедоЬ — эта функция может быть привязана к кнопке, 
меню и т. п. и обеспечивает пользователя механизмом остановки отчета, 
находящегося в процессе загрузки данных. Вы можете использовать эту 
команду в случае отключения кнопки Отмена в окне просмотра отчета с по¬ 
мощью команды РЕЗЬоѵѵРгіпіСоЩгоІз. 
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Приложение 1 


ргосебиге РЕСапсеІРгіпЫоЪ ( 


рг іпЫЪЪ : ѴГог<3 


)зСсІсаІІ; 


Параметры функции 

Описание параметров 

ргіпЬДоЪ 

Номер отчета, который необходимо отменить 


Функция РЕСапсіозеЕпдіпе — определяет возможность закрытия Сгузіаі 
Яерогі Еп§іпе. Функция вызывается перед РЕС1озеЕп§іпе для того, чтобы 
проверить состояние Ргіпі Епфпе. Если работа Сгузіаі Керогі Еп§іпе будет 
прекращена в момент обработки отчета, могут возникнуть ошибки в работе 
приложения или операционной системы. 

іипсСіоп РЕСапсіозеЕпдіпе: 

Вооі зСбсаІІ; 

Возвращаемые значения: 

□ ТІШЕ — если Ргіпі Еп§іпе может быть закрыта; 

□ РАЬЗЕ — если Ргіпі Еп§іпе занята. 

Функция РЕСЬескЕогтиіа проверяет правильность указанной формулы на 
наличие ошибок. 

іипсСіоп РЕСЬескГогшиІа ( 
ргіпЫЪЬ: Могй ; 
іоппиІаНате: РСЬаг 


): Вооі зСбсаІІ; 

Параметры функции 

Описание параметров 

ргіпСОоЪ 

Номер отчета, содержащий указанную формулу для про¬ 
верки 

ГогшиІаЫате 

Строка, содержащая имя формулы, которую требуется 
проверить 


Возвращаемые значения: 

□ ТВОЕ — если формула корректна; 

□ РАЬЗЕ — если формула имеет ошибки. 


Функция РЕСЬескСгоирЗеіесьіопРогтиіа — проверяет текст формулы, уста¬ 
навливающей ограничения на сгруппированные данные (Сгоир Зеіесііоп 
Рогшиіа), на наличие ошибок. Используйте эту функцию тогда, когда фор¬ 
мула была изменена. 
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ігипсСіоп РЕСЪескСгоирЗеІесСіопРогтиІа ( 
ргіпЫоЪ: Йога 
): Вооі зСбсаІІ; 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, содержащий формулу выборки по группе для 
проверки 


Возвращаемые значения: 

□ ТТШЕ — если формула не имеет ошибок; 
і_7 РАЕЗЕ — если формула содержит ошибки. 


Функция РЕСЪескНЫіТаЬІеОі^егепсез — ВЫПОЛНЯеТ ПОИСК рЭЗЛИЧИЙ В таб¬ 
лице базы данных и Таблице отчета. Эта функция не работает для отчетов, 
основанных на словарях. 

іипсСіоп РЕСѢескЫСМаЪІеОі і Еегепсез ( 
ргіпТЛоЪ : ЗтаІІіпР; 

ЬаЫеЫ: Зтаіііпк ; 

ЬаЫеаіііегепсеігѵЕо: РЕТаЫѳОі2: ТегепсѳІпТо) • вооі зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпС ДоЪ 

Номер отчета, содержащий таблицу базы данных, кото¬ 
рую необходимо проверить 

СаЫеЫ 

Определяет номер таблицы, для которой вы желаете из¬ 
влечь информацию. Первая таблица имеет номер 0, а 
последняя N - 1 

СаЫесІі^егепсеіпіЁо 

Запись РЕТаЫеОійегепсеІпФ, которая будет содержать 
найденную информацию 


Возвращаемые значения: 

□ ТК11Е — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен; 

□ код ошибки, см. фирменную документацию, или РЕ_ЕКК 
ТчКУЛМРЕЕМЕМТЕО, если указанный отчет сформирован на основании 
словаря. 


Функция РЕСЬескзеіесеіопРогтиіа — выполняет проверку текста формулы, 
обеспечивающей фильтрацию данных (Кесогб Зеіесйоп Роппиіа) в отчете. 


11 Зпк. 1021 
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Приложение 1 


Используйте эту функцию тогда, когда функция фильтрации данных была 
изменена и ее необходимо проверить на наличие ошибок. 

іипсСіоп РЕСЪескЗеІесСіопЕогтиІа ( 
ргіпСлТоЪ: ИогД 
): Вооі зЬйсаІІ; 


Параметры функции 

Описание параметров 

ргіпіДоЬ 

Номер отчета, содержащий формулу фильтрации дан¬ 
ных, которую необходимо проверить 


Возвращаемые значения: 

□ ТІШЕ — если формула фильтрации данных не содержит ошибок; 

□ РАЬЗЕ — если формула фильтрации данных содержит ошибки. 

Функция РЕСЬескзоьЕхргеззіоп — выполняет проверку выбранного ЗОЬ- 
выражения. Используйте эту функцию, когда 8(ЗЕ-выражение было измене¬ 
но и вам необходимо проверить получившуюся формулу. 

бипсСіоп РЕСЬескЗОЬЕхргеззіоп ( 
ргіпСДоЬ: атаІІіпЬ; 
сопзС ехргеззі оплате: РСІтг 


) : Вооі з Ссіса 11; 

Параметры функции 

Описание параметров 

ргіпб ДоЬ 

Номер отчета, содержащий ЗОЬвыражение, которое не¬ 
обходимо проверить 

ехргеззіопЫате 

Строка, содержащая имя ЗСФ-выражения, которое необ¬ 
ходимо проверить 


Возвращаемые значения: 

□ ТІШЕ — если 5С)Е-выражение не имеет ошибок; 

□ РАЬЗЕ — если 5(ЗЕ-выражение содержит ошибки. 


Функция РЕСіозеЕпдіпе — завершает работу Сгухгаі Керогі Еп§іпе. Все ак¬ 
тивные процессы завершаются, и все окна просмотра закрываются. Эта 
функция останавливает Сгузіаі Керогі Еп§іпе, но отправленные на печать 
отчеты продолжат работу. 

ргосесіиге РЕСіозеЕпдіпе зСйсаІІ; 
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Функция РЕСіозеРгіпЪіТоЬ — завершает работу выбранного отчета. Если пе¬ 
чать на принтер не завершилась, она продолжится; если окно просмотра 
отчета открыто, оно останется открытым. 

іипсСіоп РЕСІозеРгіпЫоЪ ( 


ргіпЫоЪ: ИогД 


): Вооі зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпі: ДоЬ 

Номер отчета, который необходимо закрыть 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


Функция РЕСіозеЗиЬгерогі; — закрывает выбранный подотчет. 

іипссіоп РЕСІозеЗиЪгерогС ( 


ргіпіДоЬ: Могй 


) : Вооі ЗЬСІСаІІ; 


Параметры функции 

Описание параметров 

ргіпіДоЬ 

Указатель на подотчет, который необходимо закрыть 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция ресіозѳШпсіоѵ закрывает окно предварительного просмотра. 
Используйте эту функцию для закрытия окна просмотра по событию из 
приложения либо в случае, когда кнопка <3акрыть> отключена с помощью 
функции РЕ5Но\ѵРгіпіСопігоі8. 

ргосесіиге РЕСІозеѴйпйои/ ( 
ргіпЬДоЬ: ИогЦ 
)зСЛсаИ; 


Параметры функции 

Описание параметров 

ргіпіДоЬ 

Номер отчета, окно просмотра которого необходимо за¬ 
крыть 
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Приложение 1 


Функция РЕСопѵегЬРРіп^оьоѵіп^о — конвертирует значение, возвращаемое 
в параметры СиггепіѴаІие или ОеГаиВѴаІие, функции РЕРагатеіегРіеІсІІпГо 
и записывает результат в РЕѴаІиеІпГо. 

Іипсііоп РЕСопѵегСРЕІпІоТоѴІпго ( 
ѵаіие: РСІіаг; 
ѵа ІиеТуре: Ѵ?ог<3 ; 
ѵаг ѵаіиеіпіо: РЕѴаІиеІпТо 
) : Вооі зісісаіі; 


Параметры функции 

Описание параметров 

ѵаіие 

Строка указатель на текущее значение или значение по 
умолчанию (возвращается из РЕѲеІРИІіРагатеІегРіеІсі) для 
конвертации 

ѵаІиеТуре 

Определитель типа поля параметра, из которого будет по¬ 
лучено значение. Используйте одну из констант Рагатеіег 
РіеІсІ Ѵаіие Туре Сопзіапіз: 


РЕ_РР_тМВЕК 


РЕ_РР_СЦЕКЕЦСУ 


РЕ_РГ_ВООЬЕАМ 


РЕ_РГ_ОАТЕ 


РЕ_РР_5ТКШС 


РЕ_РЕ_ОАТЕТІМЕ 


РЕ_РЕ_ТІМЕ 

ѵаіиеіпіо 

Запись РЕѴаІиеІпІо, которая используется для записи зна¬ 
чения в конвертированном виде 


Возвращаемые значения: 

□ ткіш — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСопѵегіѵш^оьоРРіп^о — конвертирует значение, записанное 
в РЕѴаІиеІпГо, в бинарное представление, используемое функцией 
РЕЗеШВіРагатеІегРіекІ. 

іипсііоп РЕСопѵегСѴІпТоТоРЕІпТо ( 
ѵаг ѵаіиеіпііо: РЕѴаІиѳІпТо; 
ѵаг ѵаІиеТуре: Иогй; 
ѵаіие: РсЬаг 
): Вооі зСйсаІІ; 
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Параметры функции 

ѵаІиеІпГо 


ѵаІиеТуре 

ѵаіие 


Описание параметров 

Запись РЕѴаІиеІпЪэ, которая содержит значение для кон¬ 
вертации 

Определитель типа конвертируемого значения 

Строка, используемая для записи значения в конвертиро¬ 
ванном виде, для передачи в РЕЗеШІбРагатеІегРіеІгі 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


Функция РЕОеіеьенььсгоирзогьріеісі — удаляет указанное поле группиров¬ 
ки (Сгоир 8ог1 ГіеМ). Эта функция используется в том случае, когда необхо¬ 
димо обеспечить возможность удаления группировки в момент работы с от¬ 
четом. Когда вы предоставляете пользователю возможность удаления 
группировки в момент печати, необходимо дать возможность изменять зна¬ 
чение, которое будет записано в $огі:РіекП\[. 

Эта функция может быть использована самостоятельно для удаления суще¬ 
ствующего поля группировки в случае, когда номер нужного поля известен 
либо в группе функций: 

□ рЕОесысгоирЗогсгіеІсіз — вызывается один раз; 

□ РЕСеМЩЬСгоирЗогСРіеІсі И РЕСеСНапсіІеЗСгіпд — вызываются совместно 
столько раз, сколько потребуется для идентификации требуемого поля; 

□ РЕОеіесеЫсьсгоирЗогсгіеіа — вызывается один раз, когда требуемое по¬ 
ле идентифицировано. 

Комбинация функций может быть использована для идентификации и по¬ 
следующего удаления существующего поля группировки и/или поля сорти¬ 
ровки как реакция на выбор пользователя в момент работы с отчетом. 

ігипсРіоп РЕБеІеРеИДЬСгоирЗогРРіеІсі ( 
ргіпЫоЪ: Йога; 
зогРЕіеіаИ: іпРедег 


): Вооі зДйсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЪ 

Номер отчета, из которого необходимо удалить поле груп¬ 
пировки 

зогТЕіеІсІЫ 

Номер поля, которое необходимо удалить. Если N = 0, 
функция удалит первое поле группировки. Если отчет 
имеет N полей группировки, функция может быть вызвана 
в диапазоне зоііРіеІсШ между 0 и N-1 
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Приложение 1 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕОеіеЬеыььрагатееетегаиіьѵаіие — удаляет значение по умол¬ 
чанию для указанного поля параметра в выбранном отчете. 

ііипсРіоп РЕЛеІеЬеИЫіРагатеЬегОеіаиІЬѴаІие ( 
ргіпЫоЪ: шпаІІіпЪ; 
сопзР рагатеСегРіеІсИате: РСЬаг; 


сопзС герогШате: 

іпйехг шпаІІіпЪ 

) : ВООЬ збйсаіі; 

РСЬаг,- 

Параметры функции 

Описание параметров 

ргіпСДоЪ 

Номер отчета, из которого необходимо удалить значение 
по умолчанию 

рагатеСегГіеІсШате 

Строка, содержащая имя поля параметра 

герогЬЫате 

Строка, содержащая имя обрабатываемого отчета 

іпсіех 

Индекс-номер значения по умолчанию, которое необходи¬ 
мо удалить 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕОеіеРеыыізогеРіеіц — удаляет указанное условие сортировки, 
поле сортировки, из списка $оп огйег. Эта функция используется в том слу¬ 
чае, когда необходимо удалить условие сортировки в момент работы с отче¬ 
том. Когда вы предоставляете пользователю возможность удаления условия 
сортировки, необходимо дать возможность изменять значение, которое бу¬ 
дет записано в зогіРіеІсГМ. 

Эта функция может быть использована самостоятельно для удаления суще¬ 
ствующего условия сортировки в случае, если номер нужного поля сорти¬ 
ровки известен, либо в группе функций: 

□ РЕСесызогсгіеісіз — вызывается один раз; 

□ РЕСеьнапсііеЗРгіпд — вызывается столько раз, сколько потребуется для 
идентификации требуемого поля сортировки; 
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□ рЕОеіеіеЫіЪЗогіГіеісі — вызывается один раз, когда требуемое поле 
иде нтифи цировано. 

Комбинация функций может быть использована для идентификации и по¬ 
следующего удаления существующего поля сортировки как реакция на вы¬ 
бор пользователя в момент работы с отчетом. 

іипсііоп РЕВеІеіеЩіЬЗогіРіеІсІ ( 
ргіпіДоЪ: Иогй; 
зогіРіеІсИ: іпіедег 
): Вооі зійсаіі; 


Параметры функции 

Описание параметров 

ргіпі ДоЪ 

Номер отчета, из которого необходимо удалить поле сор¬ 
тировки 

зогіРіеІсЩ 

Номер поля, которое необходимо удалить. Если N = 0, 
функция удалит первое поле сортировки. Если отчет имеет 

N полей сортировки, функция может быть вызвана в диа¬ 
пазоне зогІРІеІсІЫ между 0 и N - 1 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕОізсагсізаѵесіоаъа — отключает данные, которые были сохране¬ 
ны вместе с отчетом. Если отчет был сохранен с данными, вы можете, ис¬ 
пользуя эту функцию, заставить Сгузіаі КерогТ Еп§іпе обновить данные из 
источника в момент печати или вывода отчета на просмотр. 

іипсііоп РЕЛізсагсІЗаѵесІОаіа ( 
ргіпіДоЪ: Могб 
): Вооі зійсаіі; 


Параметры функции 

Описание параметров 

ргіпіДоЪ 

Номер отчета, для которого необходимо отключить ис¬ 
пользование сохраненных ранее данных 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬ5Е —- если вызов неудачен. 
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Приложение 1 


Функция РЕЕпаЫеыььдіегь включает или отключает предупреждения отчета. 

бипсСіоп РЕЕпаЫеЖЬАІегІ: ( 

ргіпЫоЪ : ЗшаІІіпЬ; 
аІегШ : йпаІІіпЪ; 
епаЫей : Вооіеап 
) : Вооіеап зСДсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЪ 

Номер отчета, для которого необходимо включить или от¬ 
ключить предупреждения 

аІегіЫ 

Номер предупреждения 

епаЫесі 

Флаг включения или отключения предупреждения. Если 
ТРЫЕ — показывать предупреждение, если РАЬЗЕ — не 


показывать 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАІ_5Е — если вызов неудачен. 


Функция РЕЕпаЫеЕѵепс — включает или отключает события. Все события 
отключены по умолчанию. 

Іипсііоп РЕЕпаЫеЕѵепі: ( 


ргіпЫЪЪ: ИОГЙ ; 

Ѵаг епаЫеЕѵепСІпіо: 

): Вооі зСйсаІІ; 

РЕЕпаЫеЕѵепСІпГо 

Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, для которого необходимо включить или от¬ 
ключить события 

епаЫеЕѵепСІпіо 

Запись РЕЕпаЫеЕѵепіІпйэ 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Функция РЕЕпаЫеРгодгеззОіаіод — определяет, будет или не будет показано 
окно прогресса. Окно прогресса показывает процесс чтения и выборки записей, 
іипссіоп РЕЕпаЫеРгодгеззОіаіод ( 
ргіШЫоЪ: Иогй; 
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епаЫе: 

Вооі 


): Вооі 

зісісаіі; 


Параметры функции 

Описание параметров 

ргіпТіТоЪ 


Номер отчета, для которого требуется показать или скрыть 
окно прогресса 

епаЫе 


Флаг включения или отключения окна прогресса. Если 
ТВУЕ — окно показывать, если РАІ.5Е — не показывать 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЕхрогъРгіпшіпаоѵ — экспортирует отчет, открытый в окне 
просмотра, в файл или отправляет по почте (Е-Маіі). Эта функция может 
быть использована в случае, когда открытый отчет удовлетворяет пользова¬ 
теля и его необходимо экспортировать, но при этом кнопка Экспорт отклю¬ 
чена с помощью функции РЕ81ю\ѵРгіпіСопІго1$. 

бипссіоп РЕЕхрогСРгіпШіпдоад ( 

.ргіпЫоЪ: Йога,- 
СОМаіІ: Вооі; 
шаіШпСіІІЭопе: Вооі 


): Вооі ЗСсЗсаІІ; 

Параметры функции 

Описание параметров 

ргіпі іТоЪ 

СоМаіІ 

иаіСЦпСіІОопе 

Номер отчета, который необходимо экспортировать 

Флаг отправки по почте (Е-МаіІ) 

Этот параметр всегда должен быть ТРЮЕ 


Возвращаемые значения: 

□ ТКІШ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЕхрогьто — экспортирует отчет, используя имя, формат и на¬ 
значение, определяемое структурой РЕЕхрогЮрІіош. Данную функцию 
можно использовать в любой момент, когда требуется получить информа¬ 
цию об отчете в формате, отличном от Сгухіаі Керот. 

іипсСіоп РЕЕхрогСТо ( 
ргіпЫоЪ: ИОГЙ; 
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ѵаг орРіопз : РЕЕхрогЬОрРіопв 
): Вооі зСйсаІІ; 


Параметры функции Описание параметров 

ргіпСДоЪ Номер отчета, который необходимо экспортировать 

орсіопз Запись РЕЕхрогЮрііопз, определяющая параметры экс¬ 

порта 

Возвращаемые значения: 

□ ТЕШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕОѳ'ЬАііои’Рготрюіаіод — определяет необходимость передачи 
параметров в выбранный отчет. 

СипсСіоп РЕСеІіАІІоиРгоггіраэіаІод ( 
ргіпЫоЪ: ЗтаІІіпТ 
) : Вооі зСсІсаІІ; 


Параметры функции 

Описание параметров 

ргіпСОоЪ 

Номер отчета, для которого требуется определить необхо¬ 
димость передачи параметров 


Возвращаемые значения: 

□ ТІШЕ — если требуется передача параметров; 

□ РАЬЗЕ — если передача параметров не требуется. 


Функция РЕСвТАгеаРогтае — возвращает параметры форматирования выбран¬ 
ного раздела отчета и подставляет его как часть структуры РЕЗесііопОрІіопх. 
Используйте эту функцию для изменения параметров форматирования и их пе¬ 
редачи обратно в отчет с помощью функции РЕЗеіАгеаРогтаі. 

ііипсСіоп РЕОеЬАгеаРогтаС ( 
ргіпСіТоЪ: Иогб 
агеаСосіе: ІпЬедег; 
орСіопз : РЕЗесРіопОрРіопз 
): Вооі зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпС ДоЪ 

Номер отчета, из которого необходимо получить парамет¬ 
ры форматирования 
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(окончание) 

Параметры функции Описание параметров 

агеаСойе Специфические коды разделов, для которых необходимо 

получить параметры форматирования: 

РЕ_АЬЬЗЕСТІОМ5 

РЕ_5ЕСТ_РАСЕ_НЕАОЕЕ 

РЕ_5ЕСТ_РАСЕ_РООТЕК 

РЕ_5ЕСТ_ЕЕРОЕТ_НЕАОЕЕ 

РЕ_8ЕСТ_ЕЕРОЕТ_РООТЕЕ 

РЕ_5ЕСТ_СЕОЦР_НЕАОЕЕ 

РЕ_ЗЕСТ_СЕОЦР_РООТЕК 

РЕ_5ЕСТ_ОЕТАІЦ 

орсіопз Запись РЕЗесііопОрііопв, которая будет получать инфор¬ 

мацию о параметрах форматирования выбранного разде¬ 
ла отчета 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Функция РЕСѳыѵгеаРогта№оппиіа — возвращает текст формулы форматиро¬ 
вания секции в виде строкового указателя. Используйте эту функцию, если 
требуется изменить формулу форматирования секции и передать изменения 
обратно в отчет с помощью функции РЕЗеіАгеаРогшаіРопииІа. Для извлече¬ 
ния текста формулы можно воспользоваться функцией РЕСеШагкИеЗігіп§. 

ііипссіоп РЕСеЬАгеаРогтаСРогтиІа ( 
ргіпЫЪЪ: Иогй ; 
агеаСойе : Иогй; 
іогтиІаНате : Иогй; 
ѵаг РехСНапйІе: ННпй; 
ѵаг СехСЬепдЙі : Иогй 
): Вооі зсйсаіі; 


Параметры функции 

Описание параметров 

ргіпС ДоЪ 

Номер отчета, из которого необходимо получить формулу 
форматирования раздела 
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(окончание) 


Параметры функции 

агеаСобе 


і'огшиІаЫаше 


СехСНапсІІе 

СехСЬепдЪЬ 


Описание параметров 

Специфические коды разделов, для которых необходимо 
получить параметры форматирования: 

РЕ_АЬЬ5ЕСТІОНЗ 

РЕ_ЗЕСТ_РАСЕ_НЕМ)ЕК 

РЕ_8ЕСТ_РАСЕ_РООТЕЕ 

РЕ_ЗЕСТ_ЕЕРОЕТ_НЕАОЕЕ 

РЕ_5ЕСТ_ЕЕРОЕТ_РООТЕЕ 

РЕ_ЗЕСТ_ОЕОІІР_НЕАОЕЕ 

РЕ_5ЕСТ_СЕООТ_РООТЕК 

РЕ_5ЕСТ_ОЕТАІЬ 

Константа, определяющая имя формулы форматирования, 
для которой вы хотите записать новую строку: 

РЕ_РРЫ_АЕЕАЗЕСТІОЫ_ѴІЗІВІЫТУ 

РЕ_РРЫ_ЗЕСТІОМ_ѴІЗІВІЫТУ 

РЕ_РРЫ_ЗНОИ_АЕЕА 

РЕ_РРЫ_ЫЕИ_РАСЕ_ВЕРОЕЕ 

РЕ_РРЫ_ЖИ_РАСЕ_АРТЕК 

РЕ_РРЫ_КЕЕР_ТОСЕТНЕЕ 

РЕ_РРМ_ЗЦРРЕЕЗЗ_ВЬАЛК_ЗЕСТІ0М 

РЕ_РРЫ_ЕЕЗЕТ_РАСЕ_И_АРТЕЕ 

ре_рры_реіыт_ат_воттом_ор_расе 

РЕ_РРЫ_ШБЕЕЬАУ_ЗЕСТІОЫ 

РЕ_РРН_5ЕСТІ0Ы_ВАСК_С0Ь0і;Е 

РЕ_РРІЯ_5ЕСТІ0М_ВАСК_С0Ь0Е 

Указатель на строку, содержащую текст формулы 

Длина строки формулы в байтах, включая заключительный 
байт 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАД5Е — если вызов неудачен. 
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Функция РЕСеЬЕпаЫеЕѵепЫп^о — возвращает информацию о возможном 
событии. Используйте функцию для того, чтобы определить, какое событие 
произойдет. 

ЕипсСіоп РЕСеСЕпаЪІеЕѵепСІпіГо ( 
ргіпЫоЪ: ѴУогД; 

Ѵаг епаЫеЕѵепЬІпіо: РЕЕпаЫеЕѵепЫпТо 
): Вооі зьйсаіі; 


Параметры функции 

Описание параметров 

ргітшоЪ 

Номер отчета, для которого необходимо получить инфор¬ 
мацию о возможных событиях 

епаЬІеЕѵепЬІпГо 

Запись РЕЕпаЫеЕѵепІІпй), содержащая информацию о 
событиях 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСѳеЕггогСосіе — возвращает номер ошибки, которая может воз¬ 
никнуть при работе функций Сгузіаі Нерон Епдіпе. Когда функция выпол¬ 
няется с ошибкой, возвращается код, на основании которого можно реали¬ 
зовать необходимую обработку. Функция РЕСеіЕггогСобе должна быть 
вызвана немедленно после возникновения ошибки. 

бипссіоп РЕСеСЕггогСоЗе ( 
ргіпьДоЬ: Иогй 
): Зшаіііпе зСйсаІІ ; 


Параметры функции 

Описание параметров 

рГІпСДоЬ 

Номер отчета, при работе с которым необходимо получать 
номера ошибок, Если функция вызывается перед тем, как 
отчет будет выбран и загружен, используйте 0 для данного 


параметра 


Возвращаемые значения: 

□ номер ошибки, если функция, вызванная ранее, выполнилась с ошибкой; 

□ О, если все работает без ошибок. 


Функция РЕСеСЕггогтехь — возвращает указатель на строку, содержащую 
информацию об ошибке, возникшей при выполнении функций Сгузіаі Кероп 
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Еп§іпе. Эта функция используется, совместно с функцией 
РЕСеіНапШе5ігіп§. Данную функцию можно использовать для отображения 
информации об ошибке в окне сообщения, совместно со своим текстом. 

ііипсСіоп РЮеЬЕггогТехь ( 
ргіпЫоЬ: МогЙ; 
ѵаг СехСНапсіІе: ГОйкЗ; 
ѵаг СехСЬепдсЪ ■. Могй 
): Вооі зьйсаіі; 


Параметры функции 

Описание параметров 

ргіпедоЬ 

Номер отчета, при работе с которым необходимо получать 
описание ошибок. Если функция вызывается перед тем, 
как отчет будет выбран и загружен, используйте 0 для 
данного параметра 

СехСНапсІІе 

Указатель на строку, содержащую текст ошибки 

СехСЬепдЫі 

Длина строки с текстом ошибки в байтах, включая завер¬ 
шающий байт 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСееЕхрогеореіопз — возвращает параметры экспорта перед тем, 
как отчет будет экспортирован. Функция РЕСеіЕхрогЮрІіош может быть 
использована для того, чтобы в виде набора диалогов отобразить параметры 
экспорта, заданные пользователем. Эти параметры используются СгузіаІ 
В.ероЛ Еп§іпе для заполнения структуры РЕЕхрогЮрііопх. В дальнейшем 
функция РЕЕхроЛТо может быть использована для того, чтобы установить 
параметры назначения отчета на основе информации в РЕЕхрогЮрііопд 

ШпсСіоп РЕСеСЕхрогСОрСіопз ( 
ргіпЫоЪ: ИогЦ ; 
ѵаг орсіопз: РЕЕхрогСОріііопз 
): Вооі зСсІсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЪ 

Номер отчета, из которого необходимо получить парамет¬ 
ры экспорта 

орСіопз 

Запись РЕЕхроПОрііопз, содержащая информацию для 
экспорта 
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Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСеЪЕ’іеіамарріпдТуре — возвращает тип планировки полей для 
указанного отчета. 

іипсСіоп РЕСеСРіеІбМарріпдТуре ( 
ргіпЫоЬ: ЗтаІІіпЪ; 
ѵаг шарріпдТуре: Йога 
): Вооі зСсісаІІ; 


Параметры функции 

Описание параметров 

ргіпі; ДоЬ 

Номер отчета, из которого необходимо получить код пла¬ 
нировки полей 

шарріпдТуре 

Константа соответствующего типа РЕ_РМ_ХХХ: 

РЕ_РМ_АОТ0_РІЛ5_МАР 

РЕ„РМ_СКРЕ_РКОМРТ_РІЮ_МАР 

РЕ_Щ_ЕѴЕНТ_ОЕРШЕП_РІЩ_МАР 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕбѳерогтиіа — возвращает текст выбранной формулы как указа¬ 
тель на строку. Эта функция используется совместно с РЕОеШапс11е$Ігіп§. 
Используйте функцию РЕЗеіРогшиІа для того, чтобы передать текст форму¬ 
лы обратно. Этот набор функций может быть использован для идентифика¬ 
ции и дальнейшего изменения существующей в отчете формулы. 

іипсСіоп РЕОеСРогтиІа ( 
ргіпЫЪЪ: Иогб; 
іогтиІаЫате : РСЬаг; 
ѵаг СехСНапсІІе; ННпЛ; 
ѵаг СехСЬепдОі : Йога 
): Вооі зСДсаІІ ; 


Параметры функции Описание параметров 


ргіпСДоЪ 


Номер отчета, из которого необходимо извлечь текст фор¬ 
мулы 
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(окончание) 

Параметры функции 

Описание параметров 

^огшиІаЫаше 

NиII-завершенная строка, содержащая имя формулы, для 
которой необходимо извлечь текст 

ТехТНапйІе 

Указатель на строку, содержащую текст формулы 

ТехТЬеп дЦЬ. 

Длина строки в байтах, включая завершающий байт 


Возвращаемые значения: 

□ ТРШЕ — если вызов удачен; 

□ РАД5Е — если указанная формула не существует в отчете. 


Функция РЕСе№огтиіаЗупЪах — возвращает информацию о синтаксисе 
Сгу$1а1/Ва$іс, использовавшемся при написании формулы, к которой обра¬ 
щались последний раз через функции АРІ. 

ргосейиге РЕСеСРогтиІаЗупСах ( 
ргіпСЛоЪ: Могй; 

ѵаг СогтиІаЗухШах: РЕЕоггпиІаЗугЛах 
) :Воо1 зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, для которого необходимо определить тип 
синтаксиса 

ЕогтиІаЗупСах 

Запись РЕРогтиІаЗупіах, которая будет содержать извле¬ 
каемую информацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСаесгарЬАхізіп^о — возвращает параметры осей для графика, 
если они доступны. 

ЕипсСіоп РЕСеССгарЪАхізІпіо ( 
ргіпЫоЬ : Иогй; 
зесСіопЛ : &па11іпе; 
дгарШ : Зшаіііпе ; 

ѵаг дгарЬАхізІпіо : РЕОгарЬАхівХпіо 
): Вооі зСйсаІІ; 
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Параметры функции 

Описание параметров 

ргіпГДоЬ 

Номер отчета, из которого необходимо получить парамет¬ 
ры осей для графика 

зесСіопЫ 

Указатель на секцию отчета, содержащую график, для 
которого необходимо получить информацию об осях коор- 


динат 

дгарЬЫ 

Номер графика, для которого требуется получить инфор¬ 
мацию об осях координат. Номер первого графика 0. Г ра¬ 
фики нумеруются в порядке их помещения в отчет 

дгарЬАхізІпЕо 

Запись РЕСгарИАхізЫо, которая будет содержать возвра¬ 
щаемую информацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


Функция РЕСеесгарЬкопЫп^о — возвращает информацию о шрифте, кото¬ 
рый используется в указанном графике. 

СипсСіоп РЕСеШгарДРопЫпЕо ( 
ргіпСДоЬ : ИогД, 
зесСіопЛ : Зтаіііпі;; 
дгарШ : ЗтаІІігЛ ; 

СіЫеРопСТуре : Могй; 

ѵаг ГопССоІоигІпГо : РЕРопССоіогіпіо 

) : Вооі зЬДсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЪ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о параметрах шрифта, установленного для графика 

зесСіопЫ 

Номер секции, в которой находится график. Этот параметр 
должен совпадать с диапазоном, возвращаемым из функ¬ 
ции РЕѲеМЗесІіопз 

дгарШ 

Номер графика, для которого требуется получить инфор¬ 
мацию об осях координат. Номер первого графика 0. Г ра¬ 
фики нумеруются в порядке их размещения в отчет 

СіСІеРопСТуре 

Используются константы типа РЕ_ОТР_ХХХ: 

РЕ_СТР_ТІТЬЕР(ЖТ 


РЕ_СТР_8ЦВТ1ТЬЕРСЖТ 

РЕ_СТР_РООТШТЕРОИТ 
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Приложение 1 
(окончание) 


Параметры функции Описание параметров 

сіЫеГопьтуре Используются константы типа РЕ_<ЗТР_ХХХ: 

РЕ_атр_акоі№5т ітьерош 1 

РЕ_аТР_ПАТАТІТЪЕРО№Г 

РЕ_СТР_ЬЕСЕтРОЫТ 

РЕ_СТЕ_СКОЦРЬАВЕЬ5ЕОМТ 

РЕ_СТЕ_ОАТАЬАВЕЬ5РОт' 

ГопесоІоигІпГо Запись РЕРопЮоіогіпіо, которая будет содержать возвра¬ 

щаемую информацию 

Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 

Функция ресѳ есгарьор ъіопіпЕ о — возвращает параметры отображения гра¬ 
фика. 

ГипсЬіоп РЕСеШгарЬОрЬіопІпіго ( 
ргіпСДоЬ : МогН; 
зесСіопЛ : ЗшаШпе; 
дгарШ : ЗтаІІігЛ; 

ѵаг дгарЬОрСіопІпГо : РЕСгарЬОреіопІпЕо 
) : Вооі зейсаіі; 

Параметры функции Описание параметров 

ргіпСДоЬ Номер отчета, из которого необходимо получить инфор¬ 

мацию о параметрах отображения, установленных для 
графика 

зессіопЫ Номер секции, в которой находится график. Этот параметр 

должен совпадать с диапазоном, возвращаемым из функ¬ 
ции РЕѲеіИЗесІіопз 

дгарШ Номер графика, Номер первого графика 0. Графики ну¬ 

меруются в порядке их размещения в отчет 

дгарЛОрсіопіпГо Запись РЕѲгарНОрііопІпЬ, которая будет содержать воз¬ 
вращаемую информацию 

Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 
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Функция РЕСеызгарЬТехыэе^аиіъоръіоп — определяет, требуется ИЛИ нет 
отображать заголовок графика, заданный по умолчанию. 

ргосейшге РЕСеШгарЬТехОЗеГаиІГОрГіоп ( 
ргіпСДоЬ: Йог Д; 
зесСіопЫ: ЗтаІІіпЬ; 
дгарЬЫ: Зтаіііпе ; 

СіСІеТуре: ИогД; 
ѵаг изеВеГаиЮ: Вооі 

): Вооі зейсаіі; 


Параметры функции Описание параметров 


ргіпСДоЪ 


зесСіопЫ 


д гарІіЫ 


СіЫеТуре 


изеЦе?аиіе 


Номер отчета, из которого необходимо получить инфор¬ 
мацию о заголовке графика по умолчанию 

Номер секции, в которой находится график. Этот параметр 
должен совпадать с диапазоном, возвращаемым из функ¬ 
ции РЕСеІИЗесііопз 

Номер графика. Нумерация начинается с 0 и заканчивает¬ 
ся N-1. Графики нумеруются в порядке их размещения в 
отчет 

Константа, определяющая тип заголовка. Используется 
один из вариантов РЕ_ОТТ_ХХХ: 

РЕ_СТТ_ТІТЬЕ 

РЕ_СТТ_5ЦВТІТЬЕ 

РЕ_СТТ_КООТЫОТЕ 

РЕ_СТТ_5ЕКІЕ5ТІТЬЕ 

РЕ_СТТ_СКОЦР5ТІТЬЕ 

РЕ_ОТТ_ХАХІ5ТІТЬЕ 

РЕ_ОТТ_УАХІЗТІТЬЕ 

РЕ_ОТТ_2АХІ5ТІТЬЕ 

Логический флаг, указывающий на необходимость ото¬ 
бражения заголовка графика по умолчанию. ТНЫЕ — необ¬ 
ходимо показать, РА1.8Е — показывать не надо 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 
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Функция РЕСеьсгарМехЫп^о — возвращает текст заголовка для выбран¬ 
ного графика. Эта функция используется совместно с функцией 
РЕОеіНапсНеЗігіпд, 

ГипсСіоп РЕОеССгарІіТехЫпіго ( 
ргіпСДоЪ: ѴУогіЗ; 
зесСіопМ: ЗтаІІіпЬ; 
дгарШ: ЗтаІІіпР ; 

СІЫ еТуре; ИогеЗ ; 
ѵаг СіЫе: Нмп<3; 
ѵаг СіСІеЬепдЫі: Зшаіііпе 

): Вооі зсйсаіі; 


Параметры функции 

ргіпСДоЪ 


зесСіопЫ 


дгарЬЫ 


ГіЫеТуре 


СіСІе 

РіРІеЬепдЫі 


Описание параметров 

Номер отчета, из которого необходимо получить текст за¬ 
головка графика 

Номер секции, в которой находится график. Этот параметр 
должен совпадать с диапазоном, возвращаемым из функ¬ 
ции РЕСеіЫЗесІіопз 

Номер графика. Нумерация начинается с 0 и заканчивает¬ 
ся N-1. Графики нумеруются в порядке их размещения в 
отчет 

Тип заголовка. Используются константы типа РЕ_ѲТТ_ХХХ: 

РЕ_СТТ_ТІТЬЕ 

РЕ_СТТ_5ШЗТІТІ<Е 

РЕ_СТТ_РООТШТЕ 

РЕ_СТТ_5ЕКІЕ5ТІТЬЕ 

РЕ_СТТ_СЕОЦРЗТІТЬЕ 

РЕ_ОТТ_ХАХІ5ТІТЬЕ 

РЕ_ОТТ_УАХІ5ТІТЬЕ 

РЕ_СТТ_2АХІ5ТІТЬЕ 

Указатель на заголовок графика 

Длина заголовка 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 







Список функций Сгузіаі Перогі Ргіпі Епдіпе АР! _ 335 


Функция РЕСеесгарЬтуреіп^о — возвращает информацию о типе указан¬ 
ного графика. 

ігипсеіоп РВЗеШгарЬТуреІпііо ( 
ргіпЬДоЬ: Иогй; 
зесРіопМ: Зтаіііпе,- 
дгарЬМ : ЗтаІІігЛ; 

ѵаг дгарЦТуреІпЕо: РЕСгарЬ.ТуреІпіо 

): Вооі зейсаіі; 


Параметры функции 

Описание параметров 

ргіпіДоЬ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о типе графика 

зесРіопЫ 

Номер секции, в которой находится график. Этот параметр 
должен совпадать с диапазоном, возвращаемым из функ¬ 
ции РЕ<Зе(№ес(іопз 

дгарЬЫ 

Номер графика. Нумерация начинается с 0 и заканчивает¬ 
ся N-1. Графики нумеруются в порядке их размещения в 
отчет 

дгарЬТуреІпіо 

Запись РЕСгарЬТуреІгЧо, в которой будет содержаться 
возвращаемая информация 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 

Функция РЕСѳесгоирсожііеіоп — определяет условие, по которому выпол¬ 
няется группирование в указанном отчете. Используется для определения 
текущего условия группирования и его изменения с помощью функции 
РЕЗеіСігоирСопсІіЧіоп, если это необходимо. 

іипсРіоп РЕСеШгоирСопсііеіоп ( 

ргіпЫЪЪ: Иогй; 

зесРіопСосІе: ІпРедег,- 

ѵаг сопйіСіопРіеІсІНапсЗІе: ННпй; 

ѵаг сопйіеіопРіеІдЬепдеЬ: ИЬгй; 

ѵаг сопйіСіоп: ѴКэгй; 

ѵаг зогиэігесРіоп: Иогй 

) : Вооі зСсісаІІ; 
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Параметры функции Описание параметров 


ргіпСЛоЪ 


Номер отчета, из которого необходимо получить ин¬ 
формацию об условиях группировки 


зесьіопСойе Код секции, для которой необходимо получить инфор¬ 

мацию об условии группировки: 

РЕ_АЬЬЗЕСТІОМ5 

РЕ_5ЕСТ_РАСЕ_НЕАОЕЕ 

РЕ_8ЕСТ_РАСЕ_РООТЕК 


РЕ_5ЕСТ_ЕЕРОЕТ_НЕАСЕЕ 
РЕ_5 ЕСТ_КЕРОКТ_РООТЕЕ 
РЕ_ЗЕСТ_СЕОЦР_НЕАОЕЕ 
РЕ_ЗЕСТ_СЕОТІР_РООТЕЕ 
РЕ_ЗЕСТ_ОЕТАІЬ 

сопйісіопРіеІйНапсіІе Указатель на поле, содержащее условие группировки 

сопйісіопРіеІйЕепдЫі Указатель длины поля, содержащего условие группи¬ 
ровки 

сопйісіоп Возвращаемый параметр. Декодирует условие и тип 

поля. Можно использовать маску для условия 
РЕ_<ЗС_СОШІТІОЫМАЗК или для типа 
РЕ_(ЗС_ТУРЕМА5К. При необходимости можно объеди¬ 
нить маски с помощью оператора И 

зогсоігессіоп Условие сортировки, установленное на группу. Исполь¬ 

зуются следующие константы 

Константа РЕ_5Р_ОЕЗСЕЩ>:гас 

Описание: сортировка данных в порядке убывания (от 7. 
к А, от 9 к 1) 

Константа РЕ_5Р_АЗСЕш:ша 

Описание: сортировка данных в порядке возрастания 
(от А к 2, от 1 к 9) 

Константа ре_зр_оеіс:шаь 

Описание: сортировка данных в том порядке, как они 
записаны в базу данных 

Константа ре„8р_зрЕСіріео 


Описание: сортировка данных в заданном порядке с 
дополнительными условиями 





Список функций СгузіаІ Перогі Ргіпі Епдіпе АРІ 


337 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСеьсгоирорЫопз — используется для определения текущих па¬ 
раметров группировки в отчете. 

бипссіоп РЕСеССгоирОрСіопз ( 
ргіпРДоЪ: ИогЦ ; 
дгоирЫ: ЗтаІІіпС; 
ѵаг дгоирОрСіопз: РЕСг оирОрР іопз 
): Вооі зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о параметрах группировки 

дгоирЫ 

Номер группы. Нумерация начинается с нуля 

дгоирОрЬіопз 

Запись РЕСгоирОрІіопз 


Возвращаемые значения: 

□ ТКЕТЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСѳесгоирЗеіесеіопРогтиіа — возвращает строку, содержащую 
текст формулы, по которой осуществляется группировка в отчете. Эта 
функция используется совместно с РЕОеШапб1е8тп§. Для изменения фор¬ 
мулы необходимо использовать РЕЗеіОгоирЗеІесІіопРогтиІа. Серия этих 
функций может быть использована для идентификации и изменения фор¬ 
мулы группировки в отчете в момент работы с ним из приложения. 

ігипсСіоп РЕОеССгоирЗеІесСіопРогтиІа ( 
ргіпЫоЪ: МогЦ ; 
ѵаг ЬехЬНапйІе: Н№ій; 
ѵаг СехСЬепдСЪ : ИогЦ 
); Вооі зСйсаІІ; 


Параметры функции Описание параметров 

ргіпСДоЬ Номер отчета, из которого необходимо получить текст 

формулы 

сехснапсііе Указатель на строку, содержащую текст формулы 
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(окончание) 

Параметры функции Описание параметров 

г.ехььепдсп Длина строки, содержащей текст формулы в байтах, 

включая завершающий байт 

Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


Функция ресѳ снашііезегіпд — возвращает текст, который связан с указате¬ 
лем типа сехснапйіе. Буфер получит текущий текст. Эта функция использу¬ 
ется совместно с функцией, возвращающей длину строки. После того как 
программа выделит буфер соответствующего размера, функция извлечет 
строку, связанную с указателем на этот буфер. 

іипсСіоп РЕСеСНапсЛеЗЬгіпд ( 

ЬехСНапсіІ е: НИгиЗ ; 

ЪиіИег: РСЬаг; 

.ЪийегЬепдЫі: ІпСедег 
) : Вооі зЬсісаІІ; 


Параметры функции Описание параметров 

СехСНапШе Указатель на строку, содержащую интересующий текст 

ЪиіДег Буфер, в который копируется интересующий текст 

Ъи^егЪепдСЬ Длина буфера в байтах, включающая пиІІ-байт заверше¬ 

ния строки. Это значение должно быть идентичным длине 
строки возвращаемой в переменную функции, опреде¬ 
ляющей эту длину 

Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕеѳедоьзеаьиз — возвращает текущее состояние отчета, откры¬ 
того с помощью функции РЕОрепРгіпПоЬ. С помощью этой функции мож¬ 
но обработать ряд программных событий. Например: 

□ для отслеживания сообщений об ошибках таких, как недостаточный объ¬ 
ем памяти, недостаточное место на диске и т. п.; 
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□ для обработки состояния на экране (песочные часы, различные графиче¬ 
ские серии и т. п ), чтобы уведомить пользователя о том, что процесс на¬ 
ходится в стадии выполнения; 

□ для поиска сомнительных моментов, из-за которых пользователем был 
остановлен процесс выполнения отчета после выполнения функции 
РЕЗіапРгіпЬІоЬ. 

іипсСіоп РЕСеСДоЪЗСаСиз ( 
ргіпЫоЪ: ИогЦ; 
ѵаг эоЬіпіо: РЕДоЫпіо 
): ЗтаІІіпС зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЪ 

Номер отчета, для которого необходимо получить статус 

ІоЫпіо 

Запись РЕДоЫпІо, которая содержит информацию, воз¬ 
вращаемую функцией 

Возвращаемые значения: 

□ возвращает 0, если функция РЕОрепЕп§іпе или РЕОрепРгіпОоЬ вызваны 
некорректно; 

□ иначе возвращает одну из констант .)оЪ Зіаіш Сошіапі$. 

Константы ѵіоЬ Зіаіиз 
Сопзіапіз 

Описание константы 

РЕ_ДОВЫОТ ЗТАКТЕ Ц 

Отчет не запущен 

РЕ_ДОВІЫРКОСКЕ 3 3 

Отчет в процессе обработки 

РЕ_ДОВСОМРЬЕТЕ 0 

Обработка отчета завершена 

РЕ_ДОВРАІЬЕЦ 

Ошибка 

РЕ_ДОВСАЫСЕЬЬЕО 

Обработка отчета отменена пользователем 

РЕ_ДОВНАЬТЕО 

Обработка отчета прекратилась из-за большого количе¬ 
ства записей или слишком большого времени ожидания 


Функция РЕСеемагдіпз — возвращает параметры границ для страницы отче¬ 
та. Данная функция используется совместно с функцией РЕ5еіМаг§іп$ для 
изменения ранее заданных параметров границ отчета. 

іипсСіоп РЕСеШагдіпз ( 
рг іпЫоЬ : ИогД ; 
ѵаг 1ебС: Иогй,- 
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ѵаг гідІЛ: Иогй ; 
ѵаг Сор: Иогй ; 
ѵаг ЪоССот: Иогй 
): Вооі зЬДсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЪ 

Номер отчета, для которого необходимо получить пара¬ 
метры границ 

ІеСс 

Значение параметра для левой границы 

гідЬС 

Значение параметра для правой границы 

Сор 

Значение параметра для верхней границы 

ЪоССот 

Значение параметра для нижней границы 


Возвращаемые значения: 

□ ТКІШ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Функция РЕбеыгоееаіісоріез — возвращает количество копий секции 
Оеіаіі в отчете, которое будет распечатано. Эта функция используется для 
получения информации о том, сколько раз каждая секция БвІаН отчета бу¬ 
дет распечатана. Чтобы изменить это количество, используется функция 
РЕЗеіКОеіаіІСоріез. 

СипсСіоп РЕСеСКГОеСаіІсоріез ( 
ргіпСЛоЪ: Иогй; 
ѵаг ііОеСаіІСоріез: ІпСедег 
): Вооі зСйсаІІ; 


Параметры функции Описание параметров 

ргіпСДоЪ Номер отчета, к которому посылается запрос на опреде¬ 

ление количества распечатываемых секций Оеіаіі 

пОеСаіісоріез Количество распечатываемых копий секции Оеіаіі 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 
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Функция РЕСеШРогтиіаз — возвращает номер формулы в указанном отчете. 
Чтобы вызвать формулу, обратившись к ней по номеру, воспользуйтесь 
функцией РЕСеі№ЬРогтиІа. 

ЕипсСіоп РЕСеШРогтиІаз ( 
ргіпЫоЪ: Нога 
): ЗтаІІіпЬ зСасаІІ; 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, в котором необходимо определить номер 
содержащейся в нем формулы 


Возвращаемые значения: 

□ номер формулы в отчете; 

□ 1 — если возникла ошибка. 


Функция РЕбѳеысгоирз возвращает номер группы в отчете. 

бипсеіоп РЕСеШСгоирз ( 
ргіпЫоЪ: йога 
) : ЗтаІІіпЬ зЬйсаИ; 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, из которого необходимо получить номер 
указанной группы 


Возвращаемые значения: 

□ номер группы в отчете; 

□ 1 — если возникла ошибка. 


Функция РЕСешсгоирзогеріеіаз — возвращает номер поля дгоир зогс 
ГіеШ в указанном отчете. Эта функция обычно используется совместно 
с другими. РЕСеіМСгоирЗогІРіеІсЗз вызывается один раз; 
РЕСеІІ'ІШСгоирЗоііРіекЗ и РЕСеШапсНеЗігігщ вызываются столько раз, 
сколько это необходимо для идентификации и коррекции дгоир зогс 
ГіеШ, и РЕЗеіКіЬАІеііСоікііІіопРогтиІа вызывается один раз, когда коррек¬ 
ция завершена. Эта серия функций может быть использована для изменения 
параметров отчета в момент его вывода на экран или на печать. 

ЕипсСіоп РЕСеШСгоирЗогРРіеІсіз ( 
ргіпЫоЪ: ИогД 
): Зтаіііпр зСасаІІ; 
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Параметры функции 

Описание параметров 

ргіпРДоЪ 

Номер отчета, для которого вы хотите получить номер 
поля дог! Веігі 


Возвращаемые значения: 

□ номер поля §гоир «огі Яеііі; 

□ О — если такого поля нет; 

□ 1 — в случае возникновения ошибки. 


Функция РЕСеШРадез — возвращает количество страниц в отчете. Эта ин¬ 
формация может потребоваться в случае, когда желательно вывести указан¬ 
ную страницу на экран с помощью функции РЕ5Но\ѵ№ЬРаёе. 

бипсРіоп РЕСеРШадез ( 
ргіпЫоЪ: ИогД 
): ЗгоаІІіпР зРйсаІІ; 


Параметры функции 

Описание параметров 

ргіпРДоЪ 

Номер отчета, для которого необходимо определить ко¬ 
личество страниц 


Возвращаемые значения: 

□ количество страниц в отчете; 

□ 1 — если возникла ошибка. 


Функция РЕСешрагатеЪегСиггепЬКапдез — возвращает количество значе¬ 
ний, определяющих диапазон для полей параметров в отчете. 

ргосеаиге РЕОеРКРагаіпеРегСиггепРКапдез ( 
ргіпрДоЪ : Зтаіііпр ; 
сопзР рагатеРегРіеІсйТаіпе : РСЬаг; 
сопзР герогШате: РСТааг; 

): Иогй зрсісаіі; 


Параметры функции 

Описание параметров 

рг іпР ДоЬ 

Номер отчета, для которого вы хотите получить текущее 
значение параметра, определенное как диапазон 

рагатеРегЕіеІсШате 

Имя поля-параметра в указанном отчете 

герогРЫаше 

Имя обрабатываемого отчета 
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Возвращаемые значения: 

□ количество значений, определяющих диапазон, связанных с указанным 
полем параметром; 

□ 1 — если возникает ошибка. 

Функция РЕСеШРагатеРегСиггепбѴаІиез — возвращает Количество значе¬ 
ний, которые в текущий момент записаны в указанное поле параметр отчета. 

іипсЬіоп РЕСеРКРагаіпеОегСиггепОѴаІиез ( 
ргіпЬіТоЪ: ЗтаІІіпЬ; 
сопзР рагатеРегЕіеІбНате: РСЬаг; 
сопзР герогРМате: РСЬаг 
): Иогй зСйсаЦ; 


Параметры функции 

Описание параметров 

ргіпрДоЬ 

Номер отчета, для которго необходимо определить коли¬ 
чество значений в поле параметре 

рагатеСегЕіеІсіЫате 

Имя поля параметра в указанном отчете 

герогСЫате 

Имя обрабатываемого отчета 


Возвращаемые значения: 

□ количество значений, записанных в указанное поле параметр; 

□ 1 — в случае возникновения ошибки. 

(_ Замечание ) 

Ожидаемые значения для параметра героПЫате: 

• для основного отчета можно определить пустую строку 

• для подотчета необходимо указать путь к файлу и имя подотчета как ЫІЛ.І.- 
завершенную строку. 

Функция РЕСеидрагате-ьегБе^аиі-ьѵаіиез — возвращает количество значе¬ 
ний, по умолчанию связанных с полем параметром в указанном отчете. 

іипсСіоп РЕСеШРагатеСегОеіаиІСѴаІиез ( 
ргіпЫоЪ: ЗшаІІіпР; 
сопзС рагатеСегЕіеІйКате: РСЬах,- 
сопзС герогШате: РСЬаг 
): Зтаіііпе зСйсаІІ; 
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Параметры функции 

Описание параметров 

ргіпРДоЪ 

Номер отчета, для которого необходимо определить ко¬ 
личество значений по умолчанию, связанных с полем 


параметром 

рагатеРегРіеІсШате 

Имя поля параметра в указанном отчете 

герогСИаше 

Имя обрабатываемого отчета 


Возвращаемые значения: 

□ количество значений по умолчанию; 

□ 1 — в случае возникновения ошибки. 


( Замечание ) 

Ожидаемые значения для параметра геройЫате: 

• для основного отчета можно определить пустую строку 

• для подотчета необходимо указать путь к файлу и имя подотчета как N111.1.- 
завершенную строку. 


Функция РЕСешРагатееегРіеіоіз — возвращает количество полей парамет¬ 
ров в указанном отчете, включая поля параметры, входящие в подотчеты. 

бипсріоп РЕОеШРагатеРегЕіеІсЗз ( 
ргіпЫоЪ : Могб 
): Зтаіііпр зРЙсаІІ; 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, из которого необходимо получить количе¬ 
ство полей параметров 


Возвращаемые значения: 

□ количество полей параметров в отчете; 

□ 1 — в случае возникновения ошибки. 


Функция РЕСе'Ьыкерог'ЬАіег'Ьз — возвращает количество предупреждений 
(Керогі Аіеііз) в указанном отчете. 

ЕипсРіоп РЕСеРШерогРАІегРз { 
ргіпЫоЪ : Зшаіііпе 
) : Зтаіііпр зРйсаІІ; 
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Параметры функции 

Описание параметров 

ргіпРДоЪ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о количестве предупреждений 


Возвращаемые значения: 

□ количество предупреждений в случае удовлетворительного вызова отчета; 

□ 1 — если отчет вызван с ошибкой. 


Функция РЕСеЫязесЫопз — возвращает количество секций в указанном от¬ 
чете. По умолчанию в стандартном отчете имеется пять секций (Верой 
Неабег, Ра§е Неабег, Оеіаіін, Кероп Рооіег и Ра^е Рооіег). Таким образом, 
функция для простого отчета вернет 5. В случае добавления в отчет группи¬ 
ровки или других секций результат увеличивается на соответствующую ве¬ 
личину. 

бипсеіоп РЕСеШЗесРіопз ( 
ргіпШГоЪ: ИогД 
): Зшаіііпе зеасаіі; 


Параметры функции 

Описание параметров 

ргіпЬДоЬ 

Номер отчета, из которого необходимо получить данные о 
количестве секций 


Возвращаемые значения: 

□ количество секций в отчете; ' 

□ 1 — если вызов отчета произошел с ошибкой. 


Функция РЕСѳьизесЬіопзіпАгеа — возвращает количество секций в указан¬ 
ной области отчета. 

ЕипсРіоп РЕСеШЗесСіопзІпАгеа ( 
ргіпДТоЪ : Иогй; 
агеаСоае : Иогй 
): ЗшаІІіпЬ зГйсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЪ 

Номер отчета, для которого необходимо определить ко¬ 
личество секций в указанной области 

агеаСосіе 

Номер области, для которой необходимо получить ин¬ 
формацию о количестве секций 
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Возвращаемые значения: 

□ количество секций в указанной области отчета, если отчет вызван без 
ошибок; 

□ 1 — если отчет вызван с ошибкой. 


Функция РЕбе-шзогеЕ’іеісіз — возвращает количество полей, по которым 
выполняется сортировка в указанном отчете. Эта функция обычно исполь¬ 
зуется совместно с функциями: 

□ РЕСеъызогшгіеісіз — вызывается один раз; 

□ РЕКерогТАІегЬІпЕо И РЕСеТНапдІеЗТгіпд — ВЫЗЫВаЮТСЯ СТОЛЬКО рЭЗ, 
сколько потребуется; 

□ РЕЗеты^ьзогрЕіеісі — вызывается один раз для коррекции идентифика¬ 
тора поля сортировки. 

Данная комбинация функций может быть использована для уточнения и 
модификации параметров сортировки в момент печати отчета. 

ігипсТіоп РЕСеШЗогРРіеІйз ( 
ргіп.Ы'оЪ: Йога 
) : ЗшаІІіпЬ збсісаіі; 


Параметры функции 

Описание параметров 

ргігЩДоЪ 

Номер отчета, для которого необходимо определить ко¬ 
личество полей сортировки 


Возвращаемые значения: 

□ количество полей сортировки; 

□ О — если полей сортировки нет; 

□ 1 — если отчет вызван с ошибкой. 


Функция РЕСеьызсшЕхргеззіопз — возвращает количество 8С>Ь-выражений 
в указанном отчете. 

ігипсТіоп РЕСеШЗОЬЕхргеззіопз ( 
ргіпТіТоЪ: ЗшаІІіпЬ 
): ЗшаІІіпЬ зРйсаІІ; 


Параметры функции 

Описание параметров 

ргіпЬДоЬ 

Номер отчета, для которого необходимо определить ко¬ 
личество 801 -выражений 
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Возвращаемые значения: 

□ количество 5<ЗЬ-выражений в отчете; 

□ 1 — при вызове отчета с ошибкой. 


Функция РЕСѳШЗиЬгерогѢзіп&есѢіоп — возвращает количество подотчетов 
в указанной секции отчета. 

іипсСіоп РЕСеШЗиЬгерогЬзІпЗесЬіоп ( 
ргіпЫоЪ: ИогД; 
зестіопСоае : ЗшаІІіпЬ 
): Зтаіііпе зСйсаІІ; 


Параметры функции Описание параметров 

Номер отчета, из которого необходимо извлечь инфор¬ 
мацию о количестве подотчетов в указанной секции 

зесСіопСойе Код секции, в которой необходимо вычислить количество 

подотчетов. Для указания кода используются константы: 

РЕ_АШЗЕСТІОЫЗ 

РЕ_ЗЕСТ_РАСЕ_НЕАЛЕЕ 

РЕ_5ЕСТ_РАСЕ_РООТЕК 

РЕ_5ЕСТ_КЕРОКТ_НЕАОЕК 

РЕ_5ЕСТ_КЕРОКТ_РООТЕК 

РЕ_5ЕСТ_СКОЦР_НЕАОЕК 

РЕ_ЗЕСТ_СКОЦР_РООТЕЕ 

РЕ_5ЕСТ_ОЕТАІЬ 

Возвращаемые значения: 

□ количество подотчетов в указанной секции; 

□ 1 — при вызове отчета с ошибкой. 


С 


Замечание 




Параметр зесІіопСойе может 
РЕОеіЗесііопСойе. 


быть 


получен с помощью 


функции 


12 Зак. 1021 
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Функция РЕСеШТаЫез — возвращает количество таблиц в открытом отчете. 
Можно использовать данную функцию для отчетов, созданных как на осно¬ 
вании настольных источников данных, так и на основании реляционных. 

ііипссіоп РЕСеШТаЫез ( 
ргіпЫЪЪ: ИогЦ 
): ЗшаІІіпЬ зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, из которго необходимо получить информа¬ 
цию о количестве таблиц 


Возвращаемые значения: 

□ количество таблиц, используемых в отчете; 

□ 1 — при вызове отчета с ошибкой. 


(_ Замечание ) 

Эта функция может работать с любыми источниками данных (Рагабох, ХЬазе, 
301 Зегѵег, Огасіе, Ыеб/ѵаге и Т. п.). 

Функция РЕОеМТаЫез должна быть вызвана после РЕОрепРгіпКІоЬ и перед 
РЕЗіагІРгіпиоЬ. 

Функция РЕСеатьЬАіегЫпзьапсеіпЕо — возвращает запись РЕАІегіІпйапсеІпГо, 
ассоциированную с выбранным предупреждением (Кероіі Аіегі). 

іипсСіоп РЕСеШСЬАІегСІпзСапсеІп^о ( 
ргіпСЛоЪ : ЗшаХІіпІ;; 
аІегШ : ЗгааІІігЛ; 
іпзСапсеЫ : Шогй; 

ѵаг аІегСІпзСапсеІпіо : РЕАІегЫпзеапсеХпіо 
) : Вооі збйсаіі; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о предупреждении 

аІегЫЯ 

Номер предупреждения, из которого необходимо полу¬ 
чить информацию 

іпзСапсеИ 

Номер экземпляра предупреждения, из которого необхо¬ 
димо получить информацию 

аІегСІпзСапсеІпіо 

Запись РЕАІейІпзіапсеІпІо, содержащая требуемую ин¬ 
формацию 
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Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


Функция РЕСешеьг’огтиіа — возвращает информацию об указанной форму¬ 
ле в отчете. Эта функция извлекает имя формулы и ее текст из отчета. Ис¬ 
пользуя данную функцию совместно с РЕЗеіЕогтиІа, можно выполнять ре¬ 
дактирование и полное изменение формулы в отчете. 

іипсеіоп рЕСеШйіРогтиІа ( 
ргіпЫЪЪ: Иогд ; 
іогтиІаКІ: ІпЪедег,- 
ѵаг патеНапйІе: Шпй; 
ѵаг патеЬепдсЬ: Иогй; 
ѵаг Сехьнапаіе: НИпй; 
ѵаг СехСЬепдсЪ: МогН 
): Вооі зтсаіі; 


Параметры функции 

Описание параметров 



ргіпСДоЪ 

Номер отчета, из которого необходимо извлечь 
мацию по формуле 

инфор- 

:Еогши1аЫ 

Номер формулы в отчете, из которой необходимо извлечь 
информацию (нумерация формул начинается с 0) 

патеНапсІІе 

Указатель на строку, содержащую имя поля 



пашеЬепдРЬ 

Длина строки, содержащей имя формулы, 
включая завершающий байт 

В 

байтах, 

ТехТНапсІІе 

Строка, содержащая текст формулы 



РехТЬепдРЬ 

Длина строки, содержащей текст формулы, 
включая завершающий байт 

в 

байтах, 


Возвращаемые значения: 

□ ТКИЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕбѳ-шеьегоирзогЪЕ'іеісі — возвращает информацию о выбранном 
поле, обеспечивающем группировку и сортировку в указанном отчете. Эта 
функция используется совместно с РЕСеШап<31е5ігіп§. РЕСе{№ЬСгоир$оііРіекі 
возвращает имя поля и порядок сортировки (по- возрастанию или убыва¬ 
нию). Также эта функция используется совместно с серией других: 

□ РЕСетысгоирЗог тгіеісіз вызывается один раз; 
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□ РЕСеСЫСІіСгоирЗогСРіеІсі И РЕСеСНапаіеЗСгіпд вызываются СТОЛЬКО раз, 
сколько необходимо для корректировки поля, обеспечивающего группи¬ 
ровку и сортировку; 

□ РЕЗеШьЬАіегьсопсіі^іопЕ’огтиіа вызывается тогда, когда выполняется 
корректировка параметров сортировки. 

бипсСіоп РЕСеШСЪСгоирЗогСРіеІсІ ( 
ргіпЫЪЪ: Иогсі; 
зогрРіеіаИ: ХпЬедег; 
ѵаг патеНапсіІе: НКпй; 
ѵаг патеЬепдСЬ: Могй; 
ѵаг дігесСіоп: Ѵ?ог<3 
): Вооі зСбсаІІ; 


Параметры функции 

Описание параметров 

ргіпРЛоЬ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о поле, выполняющем группировку и сортировку 
данных 

зогСРіеІсШ 

Номер поля, о котором необходимо получить данные. 
Нумерация полей начинается с 0 

патеНапсіІе 

Указатель на строку, содержащую имя поля 

патеЬепдСЬ 

Длина строки, содержащей имя поля, в байтах, включая 
завершающий байт 

сіігесСіоп 

Порядок сортировки. Используются следующие констан¬ 
ты: 


Константа РЕ_5Р_ОЕЗСЕш:тс 


Описание: сортировка данных в порядке убывания (от 2. 
до А, от 9 до 1) 


Константа ре_зр_азсеж>:шс 


Описание: сортировка данных в порядке возрастания (от 

А до 2, от 1 до 9) 


Константа ре_зр_окіс:шаь 


Описание: только для полей группировки. Сортировка 
данных в оригинальном порядке 


Константа ре_зр_зресіріеп 


Описание: только для полей группировки. Сортировка 
данных в специальном порядке. Только для чтения 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 
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Функция РЕСеШььРагашеьегСиггепѣЕапде — возвращает характеристики 
диапазона из выбранного поля параметра в указанном отчете. 

ргосеДиге РЕСеШСЪРагатеСегСиггепСКапде ( 
ргіпЫоЪ: ЗтаІІІгЛ ; 
сопзс рагатеСегЕіеІсВЯате : РСЬаг; 
сопзР герогШате: РСЬаг; 
іпаех : Зтаіііпр; 
ѵаг гапдеЗРагС: РЕѴаІиеХп^о; 
ѵаг гапдеЕпсЬ РЕѴаІиеХп^о; 
гапдеіпіо: ЗтаІІігЛ 
): Вооі зрсісаіі; 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, из которого необходимо получить характе¬ 
ристики диапазона 

рагаше^егГіеІсіЫаш 

е 

Строка, содержащая имя поля параметра 

герогРИате 

Строка, содержащая имя отчета 

іпйех 

Индекс параметра, для которого извлекается диапазон 

гапдеЗРагР 

Запись РЕѴаІиеІпІо, в которую возвращается начальное 
значение диапазона 

гапдеЕпсі 

Запись РЕѴаІиеіпІо, в которую возвращается конечное 
значение диапазона 

гапдеІпРо 

Константы, которые определяют правила обработки диапа¬ 
зона: 

Константа ре_кі_іысшоецрреквошц 

Значение 1 

Константа ре_кі_імсшбеьоиеквоші> 

Значение 2 

Константа ре_кі_Шцрреквошб 

Значение 4 

Константа РЕ_кі_даьоиЕКВотаго 

Значение 8 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 
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Замечание 


3 


Ожидаемые значения для параметра герогШате: 

• для основного отчета можно определить пустую строку 

• для подотчета необходимо указать путь к файлу и имя подотчета как МІЯ.І.- 
завершенную строку. 


Функция РЕСеытььрагашеьегСиггепьѵаіие — возвращает текущее значение 
параметра в указанном отчете. 

іипсРіоп РЕСеШДЬРагатеСегСиггепСѴаІие ( 
ргіпСЛЪЪ: ЗтаІІІпР ; 
сопзС рагатеСегРіеІсИате: РСЬаг; 
сопзР герогШате: РСЬаг; 
іпйех: Зтаіііпр ; 
ѵаг сиггепСѴаІие: РЕѴаІиеІпіо 
): Вооі зСДсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором Необходимо определить текущее 
значение параметра 

рагашеСегПеШЫаше 

Строка, содержащая имя поля параметра 

герогСЫаше 

Строка, содержащая имя отчета 

іпйех 

Индекс параметра, для которого извлекается значение 

сиггепСѴаІие 

Запись РЕѴаІиеІпФ, в которую значение параметра вер¬ 
нется. Если значение отсутствует, будет возвращена кон¬ 
станта РЕ_ѴІ_!ЮѴАШЕ 


Возвращаемые значения: 

□ Т1ШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ^ 

Ожидаемые значения для параметра герогІЫате: 

• для основного отчета можно определить пустую строку 

• для подотчета необходимо указать путь к файлу и имя подотчета как ЫІІИ- 
завершенную строку. 
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Функция РЕСв-ш-ььрагашеьегВегаиіьѵаіие — возвращает значение, задан¬ 
ное по умолчанию, для параметра в указанном отчете. 

іипсСіоп игСеШЙіРагатеСегОе:Еаи1СѴа1ие ( 
ргіпЫоЪ: ЗтаІІігЛ; 
сопзр рагатеСегРіеІсИате: РСЬаг; 
іпйех: атаІІіпС; 
ѵаг ѵаіиеіпіо: РЕѴаІиеіпіо 
): Вооі зСдсаІІ; 


Параметры функции 

Описание параметров 

рг іпС ДоЬ 

Номер отчета, в котором необходимо определить значе¬ 
ние параметра по умолчанию 

рагатеСегГіеІсШате 

Строка, содержащая имя поля параметра 

герогРЫаше 

Строка, содержащая имя отчета 

іпйех 

Индекс параметра, для которого извлекается значение 

ѵаіиеіпіо 

Запись РЕѴаІиеІпІо, содержащая информацию о запра¬ 
шиваемом значении по умолчанию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ) 

Ожидаемые значения для параметра герогіЫате: 

• для основного отчета можно определить пустую строку 

• для подотчета необходимо указать путь к файлу и имя подотчета как N1111- 
завершенную строку. 


Функция РЕСеідтыіРагатееегРіеісі — возвращает информацию об одном из 
полей параметров в указанном отчете. Эта функция возвращает имя поля, 
тип данных и информацию о значении поля. Эта функция чаще всего ис¬ 
пользуется совместно с другими: 

□ РЕСеСЫРагатеРегГіеІсіз Вызывается ОДИН раз; 

□ РЕСеьшщрагатеьеггіеісі вызывается столько раз, сколько это необходи¬ 
мо для корректировки поля параметра; 
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□ РЕЗеьыььрагатеЬегЕіеісі вызывается один раз для коррекции идентифи¬ 
катора поля параметра. 

^ипсеіоп РЕСеШЬЬРагаліеТегРіеІсі ( 
ргіпЫоЪ: Когй; 
ѵа гМ: ЗтаІІіпЬ ; 

ѵаг ѵагіпбо: РЕРагатеСегЕіеІііІпЕо 

): Вооі зЪйсаІІ; 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, который содержит поле параметр, о кото¬ 
ром необходимо получить информацию 

рагашеРегЫ 

Номер параметра, о котором необходимо получить ин¬ 
формацию 

рагашеРегІпіо 

Запись РЕРагатеІегРіеІбІпІо, которая используется для 
записи полученной информации 


Возвращаемые значения: 

□ ТКЦЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


Функция РЕСеыяЫіРагатееегТуре — возвращает тип указанного параметра. 

бипсеіоп РЕСеШСЬРагатеСегТуре ( 
ргіпЫоЪ; Ктаіііпе ; 
іпйех: ЗшаІІіпР 
): ЗтаІІіпС зСЛсаІІ; 


Параметры функции 

Описание параметров 

ргіпбДоЬ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о типе параметра 

іпйех 

Индекс поля параметра 


Возвращаемые значения: 

□ Р Е Р 0_ К Е РО КТ — отчет; 

□ РЕ_РО_5ТОКЕОРКОС — хранимая процедура; 

□ РЕ_РО_дііЕКУ - запрос; 

□ — 1 — индекс неверен. 
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Функция РЕСе’ЬЦиіРагаіпеЬегѴаІиеОезсгір'Ьіоп — ВОЗВращаеТ текст ПОД- 
сказки для параметра. 

бипсОіоп РЕСеСНОЬРагатеОегѴаІиеІЭезсгірСіоп ( 
ргіпЫоЪ : Зшаіііпе ; 
рагатеСегРіеІсКате : РСЗіаг; 
герогШате : РСЬаг ; 
іпаех : ЗтаІІіпЬ; 
ѵаг ѵаІиеРезс : НМпд,- 
ѵаг ѵаІиеРезсЬепдЫі : Зтаіііпе 
); Вооі зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпОДоЬ 

Номер отчета, из которого необходимо извлечь описание 
для указанного параметра 

рагашеТегГіеІсіЫаше 

Строка, содержащая имя поля параметра, для которого 
необходимо получить описание 

герогШаше 

Строка, содержащая имя отчета 

іпйех 

Индекс параметра, для которого извлекается значение 

ѵаІиеОезс 

Указатель на описание, которое было возвращено 

ѵа1ие0езсЬепд*:Ь 

Длина строки, содержащей описание параметра 


Возвращаемые значения: 

□ ТКЕТЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


С Замечание 

Ожидаемые значения для параметра герогІЫате: 

• для основного отчета можно определить пустую строку 

• для подотчета необходимо указать путь к файлу и имя подотчета как N1111- 
завершенную строку. 


Функция РЕОѳ-шськерогеАіегс — возвращает запись (структуру) 
РЕКерогіАІеіІІпГо из отчета. Запись РЕКерогіАІеіІІпГо содержит информа¬ 
цию об определенном предупреждении (Керогі Аіеіі). 

бипсОіоп РЕСеШОШерогТАІегО ( 
ргіпОіТоЬ : ЗшаІІІпЬ; 
аІегОИ : ЗшаШпС; 

ѵаг герог гАІегЫпго : РЕКерогЬАІѳгЬІпЕо 
) : Вооіеап зОйсаІІ; 
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Параметры функции Описание параметров 

ргіпМоЬ Номер отчета, из которого необходимо извлечь инфор¬ 

мацию о предупреждении 

аІегДЫ Номер экземпляра предупреждения (Нерогі АІегІ), для 

которого необходимо получить информацию 

герогЬАІегЫпіо Запись РЕАІеДІпзіапсеІпФ 

Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕбѳшеьзог№іеіа — возвращает информацию об одном из по¬ 
лей, по которому выполняется сортировка в указанном отчете. Эта функция 
возвращает имя поля, по которому выполняется сортировка, и направление 
сортировки (по возрастанию или по убыванию). Имя поля возвращается как 
указатель на строку. Данная функция обычно используется совместно 
с другими: 

□ РЕСеДЧ5оііРіекі$ вызывается один раз; 

□ РЕСеіМФЗоііРіеІсі и РЕОеШапб1е8тп§ вызываются совместно столько 
раз, сколько это необходимо; 

□ РЕЗеіІЧіКЗогіРіеІсі вызывается один раз для выполнения коррекции поля, 
обеспечивающего сортировку. 

бипсДіоп РЕСеЬЩДіЗогЬРіеІсІ ( 
ргіпЫоЪ: Иог<3; 
зогДРіеІбИ: ігЛѳдег,- 
ѵаг патеНапсІІе: Н№кЗ; 
ѵаг патеЬепдДЬ: Мог <3 ; 
ѵаг йігесДіоп: ѴТогй 
): Вооі зДсІсаІІ; 


Параметры функции 

Описание параметров 

ргіпДДоЬ 

Номер отчета, для которого необходимо получить ин¬ 
формацию о поле, по которому выполняется сортировка 

зогДГіеІйЫ 

Номер поля, для которого необходимо получить инфор¬ 
мацию. Нумерация полей начинается с 0 

патеНапЦІе 

Указатель на строку, содержащую имя поля 

пашеЬепдЩі 

Длина строки, содержащей имя поля, в байтах, включая 
завершающий байт 
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(окончание) 


Параметры функции Описание параметров 

сіігесгіоп Константа, определяющая направление сортировки: 

Константа ре_зр_бе5Сешіш 

Описание — сортировка данных в порядке убывания (от 2 
до А, от 9 до 1) 

Константа ре_зр_азсешіш 

Описание — сортировка данных в порядке возрастания 
(от А до 2, от 1 до 9) 

Константа ре_зр_окіс:шаь 

Описание — только для полей группировки. Сортировка 
данных в оригинальном порядке 

Константа ре_зр_зресіріеб 

Описание — только для полей группировки. Сортировка 
данных в специальном порядке. Только для чтения 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Функция РЕСѳШеьзоьЕхргеззіоп — возвращает 80Ь-выражение, включен¬ 
ное в отчет. Эта функция используется совместно с РЕСеіНапсі1е8іпп§. 

бипсеіоп РЕСеШДЬЗОЬЕхргеззіоп ( 
ргіпДТоЪ: ЗтаІІіпЬ • 
ехргеззіоііЦ: ЗтаІІіпС; 
ѵаг патеНапйІе: НМгиі; 
ѵаг патеЬепдОі: ЗтаІІііЛ; 
ѵаг ЬехРНапаІе -. НКпД; 
ѵаг ЬехІЩепдОі: Зтаіііпр 
): Вооі зЬйсаІІ; 


* 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию об 801-выражении 

ехргеззіопЫ 

Номер, указывающий на выражение, которое необходимо 
извлечь 

пашеНапШе 

Указатель на строку, содержащую имя ЗСЦ-выражения 
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(окончание) 

Параметры функции 

Описание параметров 

патеЬепдСІі 

Длина строки, содержащей имя ЗСЛ-выражѳния, в бай¬ 
тах, включая завершающий байт 

ЬехЬНапсІІе 

Указатель на строку, содержащую ЗОЬвыражение 

ЬехЬЬепдЫі 

Длина строки, содержащей ЗОЬ-выражение 

Возвращаемые значения: 

□ ТКЕІЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 

Функция РЕСешььзиЬгерогЫпЗесЫоп — возвращает указатель, который 
необходим для получения имени подотчета. 

РипсРіоп РЕСеІДІРЪЗиЬгерог 1: ІпЗесЬіоп ( 
ргіпсДоЬ: Йога; 
зесРіопСосІе: Зшіііпі; 
зиЪгерогШ: ЗтаІІіпР 
) : ВНога зЬсІсаІІ; 

Параметры функции 

Описание параметров 

ргігШДоЪ 

Номер отчета, который является основным 

зесЪіопСосіе 

Константа, указывающая на секцию отчета, в которой 
находится подотчет: 


РЕ_АЬЬ5ЕСТІОН5 


РЕ_5ЕСТ_РАСЕ_НЕА0ЕК 


РЕ_ЗЕСТ_РАСЕ_РООТЕК 


РЕ_ЗЕСТ_ЕЕРОКТ_НЕАОЕЕ 


РЕ_5ЕСТ_ЕЕРОЕТ_РООТЕЕ 


РЕ_ЗЕСТ_СЕОЦР_НЕАБЕЕ 


РЕ_5ЕСТ_СЕ0ЦР_Р00ТЕЕ 


РЕ_5ЕСЩ0ЕТАІЬ 

зиЪгерогЬЫ 

Номер подотчета в указанной секции. Нумерация подот¬ 
четов начинается с 0. Если подотчетов нет в указанной 
секции, функция вернет 0 


Возвращаемые значения: указатель, который используется для получения 
имени интересуемого подотчета. 
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( Замечание ) 

Используйте РЕСеіЗиЬгерогІІпЬ, чтобы получить информацию о подотчете, 
указатель для которого вернет функция РЕОеіЫФЗиЬгерогІІпЗесІіоп. 

Функция РЕбеШУтТаЫеЬосаъіоп — определяет местонахождение таблицы 
используемой в отчете. Эта функция обычно используется совместно 
с РЕЗегТЧитТаЫеЬосабоп для внесения изменений в настройки отчета, свя¬ 
занные с местонахождением таблиц. 

бипсьіоп РЕСеШЫіТаЫеЬосаЫоп( 
ргіпЫЪЪ: МогД; 

ТаЫеЫ: ІгЛедег ; 

ѵаг ІосаЬіоп: РЕТаЫеЬосаЬіоп 

) : Вооі зДсЭсаІІ; 


Параметры функции 

Описание параметров 

ргігЩДоЪ 

Номер отчета, из которого необходимо извлечь инфор¬ 
мацию о местоположении таблиц, используемых для 
формирования набора данных для отчета 

РаЫеЫ 

Номер таблицы, используемой при формировании отчета. 
Нумерация таблиц начинается с 0 

Іосаріоп 

Запись РЕТаЫеІ.осаІіоп, содержащая данные о таблице. 
Формат строки зависит от типа источника, используемого 
для формирования отчета 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция рЕбеытььтаЫеьодОпіп^о — возвращает информацию об имени 
сервера, имени базы данных, имени пользователя и другую информацию, 
необходимую для подключения отчета к источнику данных. 

бипсЬіоп РЕСеШРМаЫеЬодОпІпііо ( 
рГІпЫоЬ: НогД; 

РаЫеЛ: ІпРедег ; 

ѵаг ІодОпІпііо: РЕХіодОпІпСо 


): Вооі зьдсаіі; 

Параметры функции 

Описание параметров 

ргіпр ДоЬ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о том, как подключаться к таблице в источнике 


данных 
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(окончание) 

Параметры функции 

Описание параметров 

СаЫеЫ 

Номер таблицы, используемой для построения отчета. 
Нумерация таблиц начинается с 0 

ІодОпІпіГо 

Запись РЕІ_одОпІп(о, содержащая всю необходимую для 
подключения к базе данных информацию 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАБ5Е — если вызов неудачен. 

{ Замечание ~ ) 

Эта функция должна вызываться после РЕОрепРгіпБоЬ, так как для нее необ¬ 
ходим номер отчета, и перед РЕЗІагіРгіпЕІоЬ, для которой может потребовать¬ 
ся указать пароль для подключения к базе данных. Строка пароля, хранимая 
в записи (структуре) РЕІ_одОпІЩо, будет всегда пустой при использовании дан¬ 
ной функции. 

Функция РЕСешіьтаЫѳРгіѵасвіпго — возвращает информацию об ис¬ 
пользовании таких объектов, как АБО, ОАО, КЕЮ или СБО с соответст¬ 
вующими драйверами Асиѵе Баш Бгіѵеге (сгбЬабо.сШ, сгсіЬ_бао.сШ, 
сгсіЬ_осіЬс.сШ, сгсіЬ_ссіо.(і11). 

бипсСіоп РЕСеШСЬТаЫеРгіѵаСеІпіо ( 
ргіпЫоЪ: МогЦ ; 

СаЫеЛ: йпаІІіпС; 

ѵаг ргіѵаТеІпго: РЕТаЫеРгіѵаРеІпіо 

) : Вооі зрсісаіі; 


Параметры функции 

Описание параметров 

ргіпС ДоЬ 

Номер отчета, который использует таблицы, требующие 
информацию о сессии связи с источником 

СаЫеЫ 

Номер таблицы, для которой необходимо получить ин¬ 
формацию. Нумерация таблиц начинается с 0 

ргіѵаСеІпіго 

Запись РЕТаЫеРгіѵаіеІпІо, содержащая необходимую 
информацию 


Возвращаемые значения: 

□ ТК.БЕ — если вызов удачен; 

□ РАБ5Е — если вызов неудачен. 
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Функция РЕОеьысьтаЫѳзеззіопіпго — возвращает информацию о сессии 
для таблиц Місговой; Ассе88, используемых в отчете. Данная функция воз¬ 
вращает следующую информацию: Шег ГО, Ра88\ѵогс1 и 5е88Іоп Напбіе. 

бипсРіоп РЕСеШЫіТаЫеЗеззіопІпіо ( 
ргіпЬДоЬ: МогД; 

РаЫеІТ: ІпСедег ; 

ѵаг зеззіопіпбо: РЕЗевБІопХпСо 

): Вооі зьйсаіі; 


Параметры функции 

Описание параметров 

ргіпР ДоЬ 

Номер отчета, требующий получения информации о сес¬ 
сии 

СаЫеЫ 

Номер таблицы, используемой в отчете. Нумерация таб¬ 
лиц начинается с 0 

зеззіопіпі'о 

Запись РЕЗеззіопІпІо, которая содержит требуемую ин¬ 
формацию 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


у Замечание ^ 

Эта функция может быть использована только для баз данных М8 Ассезз, ко¬ 
торые требуют открытия сессии, прежде чем будет обеспечен доступ к базе. 
Строка, содержащая пароль, в записи (структуре) РЕЗеззіопІФо будет всегда 
пустой. 


Функция РЕбеышіТаЫеТуре — определяет тип каждой таблицы. Эта функ¬ 
ция одна из серии функций, которые обеспечивают возможность получения 
и изменения параметров работы отчета с базами данных. 

бипсСіоп РЕОеШСКГаЪІеТуре ( 
ргіпЫоЪ: Иогй; 

СаЫ еЫ: ІпЪедѳх ; 

ѵаг СаЫеТуре: РЕТаЫеТуре 

): Вооі зОйсаІІ ; 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, в котором необходимо определить тип таб¬ 
лицы 
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(окончание) 

Параметры функции 

Описание параметров 

ТаЫеЫ 

Номер таблицы, входящей в отчет. Нумерация начинается 
с 0. То есть в случае, когда функция РЕбеШТаЫез вернет 

2, вызывайте функцию РЕОеіЫФТаЫеТуре дважды с но¬ 
мерами 0 и 1 

ТаЫеТуре 

Запись РЕТаЫеТуре, возвращающая требуемую инфор¬ 
мацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


( Замечание ) 

Приложение может протестировать ОВТуре в РЕТаЫеТуре или библиотеку ба¬ 
зы данных ОНЫате, используемые для создания отчета: 

• имена библиотек имеют следующие правила наименования: сгсіЬ_*.сІІІ для 
стандартньіх (нереляционных) баз данных и ЗСЛ/СЮВС баз данных; 

• в случае использования СЮВС-источников (сгсіЬ_ос)Ьс.с)ІІ), и строка 
ОезсгірІіѵеЫате в РЕТаЫеТуре содержит имя используемого СЮВС 08N. 

РЕОеШІІіТаЫеТуре должна вызываться после РЕОрепРгіпЫоЬ и перед 
РЕЗІаПРгіпЫоЬ. 


Функция РЕбѳсрагатесегміпМахѵаіие — возвращает возможные максималь- 
ное и минимальное значения для указанного параметра в отчете. 

бипсбіоп РЕСеСРагашеСегМіпМахѴаІие ( 
ргіпЫоЪ: ИогД; 

сопзС рагатеСегЕіеІсИате : РСЬаг; 
сопзС герогШате: РСЬаг; 
ѵаг ѵаІиеМіп: РЕѴаІиеІпіо; 
ѵаг ѵаІиеМах: РЕѴаІиеІпЕо 
) : Вооі БСсЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпС ДоЬ 

Номер отчета, в котором необходимо вычислить мини¬ 
мальное и максимальное значение параметра 

рагашеСегГіеІсіЫаіпе 

Строка, содержащая имя поля параметра 

герогСЫаше 

Строка, содержащая имя отчета 
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(окончание) 


Параметры функции Описание параметров 

ѵаІиеМіп Запись РЕѴаІиеІпйэ, в которую возвращается информация 

о минимальном значении параметра 

ѵаІиеМах Запись РЕѴаІиеІпФ, в которую возвращается информация 

о максимальном значении параметра 


Возвращаемые значения: 

□ ТК.ІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Замечание ) 

Ожидаемое значение параметра герогШате: 

• для основного отчета пустая строка 

• для подотчета пути и имени подотчета как строка, завершающаяся Ы1ЛІ. 
Ожидаемые значения для параметров ѵаІиеМіп и ѵаІиеМах: 

• установите ѵаІиеМіп в N1)11. для получения только максимального значения 
и установите значение, отличное от ЫІАІ, если ѵаІиеМах равно N111.1; 

• установите ѵаІиеМах в ЫІІИ для получения только минимального значения 
и установите значение, отличное от -N1111, если ѵаІиеМіп равно N1111. 


Функция РЕСеЪРагатеъегРіскдізсорсіоп — возвращает список настроек 
параметра в отчете. Эта функция записывает значения в запись (структуру) 
РЕРагатеіегРіскІдзЮрПоп. 

бипсеіоп РЕСееРагатеОегРіскЬізООрОіоп ( 
ргіпЫоЪ: ИогД; 
рагатеОегРіеІсіМате : РСЬаг,- 
герогШате : РСЬаг; 

ѵаг ріскЬізРОрРіоп : РЕРагатеСегРіскЬівеОреіоп 

) : Вооі зСсЭсаІІ; 


Параметры функции Описание параметров 

ргіпРДоЬ Номер отчета, из которого необходимо извлечь список 

настроек для параметра 

рагатеЬегГіеІсШате Строка, содержащая имя параметра, для которого необ¬ 
ходимо получить список настроек 

герогОЫаше Строка, содержащая имя отчета 

ріскЬізООрріоп Запись РЕРагатеІегРіскивЮрІіоп, которая будет содер¬ 

жать возвращаемую информацию 
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Возвращаемые значения: 

□ ТК.1Ш — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


С Замечание ^ 

Ожидаемое значение параметра герогШате: 

• для основного отчета пустая строка 

• для подотчета пути и имени подотчета как строка, завершающаяся N111.1-. 


Функция РЕбѳЬРагатаеегѴаіиеіп^о — возвращает запись РЕРагатеіегѴаІиеІпГо, 
связанную с указанным полем параметров в отчете. Эта запись содержит 
информацию следующего рода: 

□ возможность редактирования значений параметра; 

□ допустимость использования значения ІѵІШХ; 

□ разрешение использовать множество значений; 
и т. п. 

бипсРіоп РЕСеРРагатеРегѴаІиеіпбо ( 
ргіпЫоЬ : Могд; 

сопзР рагатеГегРіеІсЭШте : РСЬаг,- 
сопзР герогШат : РСЬаг; 
ѵаг ѵаіиеіпбо : РЕРагалеЬегѴаІиеІпіо 
): Вооі зРдсаІІ; 


Параметры функции 

Описание параметров 

ргіпЬДоЬ 

Номер отчета, из которого необходимо получить инфор¬ 
мацию о параметре 

рагатеРегГіеІсШате 

Строка, содержащая имя поля параметра 

герогШате 

Строка, содержащая имя отчета 

ѵаІиеІпіГо 

Запись РЕРагатеІегѴаІиеІпй), в которую будут возвраще¬ 
ны интересующие данные 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 
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( Замечание ^ 

Ожидаемое значение параметра герогШате: 

• для основного отчета пустая строка 

• для подотчета пути и имени подотчета как строка, завершающаяся N111.1-. 


Функция РЕСѳъРгіпаэаъе — определяет дату печати, которая определена в 
отчете. Используется эта функция для считывания имеющегося значения и 
передачи нового с помощью функции РЕЗеіРгіпШаІе. 

іипсеіоп РЕСеСРгіпЫЗаее ( 
ргігЛіТоЪ: МогЦ; 
ѵаг уеаг: НогД; 
ѵаг топЬЬ: Иог<3,- 
ѵаг Йау: Иогд 
): Вооі зейсаіі; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

уеаг 

шопЫі 

йау 

Номер отчета, для которого необходимо узнать дату печати 

Номер, соответствующий году (4 цифры) 

Номер, соответствующий месяцу (2 цифры) 

Номер, соответствующий числу (2 цифры) 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ) 

Изменение значения даты печати может потребоваться в случае, когда вы пе¬ 
чатаете отчет сегодня, а дата печати должна стоять другая. 


Функция РЕСеергіпеорьіопз — возвращает параметры печати, которые оп¬ 
ределены для отчета. Эта функция используется для выяснения текущих па¬ 
раметров печати и их последующего изменения с помощью функции 
РЕЗеіРгіпЮрІіош. 

Ьлпсбіоп РЕСеЬРгіпСОрСіопз ( 
ргіпСДоЬ: Иогй ; 
ѵаг орЬіопз: РЕРгіпеОреіопз 
) : Вооі зЫсаІІ; 
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Параметры функции 

Описание параметров 

ргіпіДоЬ 

Номер отчета, к которому направляют запрос для выяс¬ 
нения текущих параметров печати 

орбіопз 

Запись РЕРгіпЮрІіопз, в которую возвращаются запро¬ 
шенные данные 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСѳекерогеоръіопз — возвращает информацию об основных на- 


стройках указанного отчета. 

ігипсеіоп РЕСесКерогсОрсіопз ( 

ргіпбіТоЪ: НогД; 
ѵаг герогРОрріопз : 

РЕКерогТОрР іопз 

): Вооі зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпбДоЪ 

Номер отчета, для которого требуется узнать информа¬ 
цию об основных настройках 

герогР0р1:іопз 

Запись РЕПерогіАІегІІпІо, содержащая требуемую ин¬ 
формацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕбеікѳрогезшптагуіп^о — возвращает суммарную информацию 
об отчете: 

□ заголовок отчета; 

□ автор; 

□ комментарии. 

ЬлпсРіоп РЕСеРКерогРЗиштагуІпііо ( 
ргіпРДоЪ : НогД ; 

ѵаг зиттагуіпііо: РЕКѳрогеЗилтагуІпіо 

): Вооі зРйсаІІ; 
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Параметры функции 

Описание параметров 

ргіпСОЪЪ 

Номер отчета, о котором необходимо узнать информацию 

зшптагуІпТо 

Запись РЕЯерогіЗиттагуІпЯ), получающая запрашивае¬ 
мую информацию 

Возвращаемые значения: 

□ ТЯІШ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Функция РЕСеькерогетіеіе — возвращает указатель на строку, содержащую 
заголовок отчета. Если выбран подотчет, то возвращается указатель на имя 
подотчета. Функция используется совместно с РЕСеШапб1е8ичп§. Для из¬ 
менения заголовка отчета используется функция РЕЗеіКеропТіГІе. 

ігипсСіоп РЕСеСКерогСТіСІе ( 

ргіпЫ'оЪ: Иог<1; 
ѵаг ЬіСІеНапсІІе: 

нтапй; 

ѵаг ЫЫеЬепдЬЬ: 

йога 

): Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпЬДоЬ 

Номер отчета, из которого необходимо получить данные о 


заголовке 

ЫЫеНапШе 

Указатель на строку, содержащую заголовок отчета 

СіСІеЬепдЫі 

Длина строки с заголовком отчета в байтах, включая за¬ 
вершающий байт 


Возвращаемые значения: 

□ ТШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕбеекерог'ЬѴегзіоп — возвращает запись РЕѴегзіопІпГо, связан¬ 
ную с отчетом. Запись РЕѴегмопІпГо содержит информацию о версии отчета. 

ЕипсЬіоп РЕѲеСКерогСѴегзіоп ( 
ргіпЫоЬ : ЗтаІІіпЪ; 
ѵаг рѴегзіопІпЕо : РЕѴегзіопІпГо 
): Вооі зЬЗсаІІ; 
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Параметры функции Описание параметров 

ргіпс ДоЬ Номер отчета, для которого требуется информация о вер¬ 

сии 

рѵегзіопіпіо Запись РЕѴегзіопІггіо 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСеъзесЫопСосіе — возвращает код секции. Код секции опреде¬ 
ляет ее тип (Ра§е Неасіег, Оеіаііз и т. п.). Если отчет имеет несколько усло¬ 
вий группировки, то секции группировки идентифицируются номером 
группы. В случае наличия множественных секций в одном разделе их иден¬ 
тифицируют по номеру секции. 

ЕипсСіоп РЕСеСЗесСіопСосіе ( 
ргіпЫоЬ: Иог<3,- 
зесСіогШ: БтаІІіггЬ 
) : Етаіііпе зЫсаІІ; 


Параметры функции Описание параметров 

ргіпСДоЬ Номер отчета, из которого извлекают код секции 

зесьіопы Номер секции в отчете, для которой необходимо узнать 

код. Этот параметр должен попадать в диапазон значе¬ 
ний, возвращаемых функцией РЕОеШЗесІіопз 


Возвращаемые значения: 

□ РЕ_АЕЕ5ЕСТІ(Ж5 

□ РЕ_5ЕСТ_РАСЕ_НЕАОЕК 

□ РЕ_5ЕСТ_РАОЕ_РООТЕК 

□ РЕ_5ЕСТ_КЕРОКТ_НЕАОЕК 

□ РЕ_5ЕСТ_ВЕРОКТ_РООТЕК 

□ РЕ_8ЕСТ_ОКОІІР_НЕАОЕІІ 

□ РЕ_5ЕСТ_СКОІІР_РООТЕК 

□ РЕ_5ЕСТ_ОЕТАІЬ 

□ О — если при вызове функции произошла ошибка 
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Функция РЕСеъзесъіопЕ’огта'Ь — возвращает параметры форматирования 
секции для последующего их использования в РЕЗесІіопОрІіопз. Эта функ¬ 
ция используется в случае необходимости изменения параметров формати¬ 
рования секции с помощью функции РЕЗеіЗесІіопРоітпаІ:. 

ЕипсСіоп РЕОеСЗесСіопРогтаЬ ( 
ргіпЫоЪ: ИогД; 
зесЬіопСосІе: ІпЪедѳг; 
ѵаг орСіопз: РЕЗесгЫопОр-Ыопз 
): Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпСЦоЬ 

Номер отчета, в котором необходимо узнать информацию 
о параметрах форматирования указанной секции 

зесСіопСойе 

Код секции, для которой требуется получить информа¬ 
цию. Код секции можно получить с помощью функции 
РЕѲеІЗесІіопСосІе 

орСіопз 

Запись РЕЗесііопОрІіопз, в которую будет записана тре¬ 
буемая информация 


Возвращаемые значения; 

□ ТК.ІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕбеезесеіопГогтаЪЕ'огшиіа — возвращает текущую формулу, 
обеспечивающую форматирование указанной секции в отчете. Данную 
функцию необходимо использовать совместно с РЕОеШапсіІеЗігіпё. 

іипссіоп РЕѲеСЗесСіопРогтпаЬРогтиІа ( 
ргіпЫоЪ: Иогй; 
зесСіопСойе; Мог Д; 
іогшиІаЫаше: ИогД ; 
ѵаг ЬехСНапйІе: НШй; 
ѵаг ЬехЬЬепдСЬ: Иогй 
): Вооі зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпСЦоЬ 

Номер отчета, в котором необходимо узнать формулу 
форматирования выбранной секции 

зесСіопСойе 

Код секции, который может быть получен с помощью 
функции РЕѲеіЗесІіопСогіе 









370 


Приложение 1 


(окончание) 

Параметры функции Описание параметров 

іогшиІаЫаше Имя формулы, обеспечивающей форматирование. Ис¬ 

пользуются константы: 

Константа ре_ретя_аееА5ЕСТіоы_ѵі5івіьіту 

Описание — формула форматирования области отчета и 
отдельной секции 

Константа ре_рры_5ЕСТіоы_ѵі8івіьіту 
Описание — формула форматирования секции 
Константа ре_рры_знои_акеа 

Описание — формула форматирования области отчета 
Константа ре_ррія_ыем_расе_вероее 

Описание — формула форматирования области отчета и 
отдельной секции 

Константа ре_рры_ыеи_расе_артек 

Описание — формула форматирования области отчета и 
отдельной секции 

Константа РЕ_РРЫ_КЕЕР_ТООЕТНЕЕ 

Описание — формула форматирования области отчета и 
отдельной секции 

Константа РЕ_РРЫ_5і;РРЕЕ38_ВЬАЫК_5ЕСТІСЖ 

Описание — формула форматирования секции 
Константа ре_ррм_еезет_расе_ія_артее 

Описание — формула форматирования области отчета и 
отдельной секции 

Константа ре_ррк_ркіыт_ат_воттом_ор_расе 

Описание — формула форматирования области отчета и 
отдельной секции 

Константа ре_рры_цж>екьау_зест10Ы 
Описание — формула форматирования секции 
Константа ре_ррк_зестісэд_васк_соьоие 
Описание — формула форматирования секции 
Константа ре_ррк_зестіоы_васк_соьое 
Описание — формула форматирования секции 
ЬехСНапсііе Указатель на строку, содержащую текст формулы фор¬ 

матирования 

ьехсъепдсь Длина строки, содержащей текст формулы форматиро¬ 

вания. Используйте данное значение для выделения па¬ 
мяти под текст 
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Возвращаемые значения: 

□ ТК.ІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ^ 

Не все имена формул применимы в различных секциях отчета. Используйте 
значение ІехНепдЩ для выделения памяти под текст. Используйте функцию 
РЕОеІНапйІеЗІгіпд для того, чтобы заполнить выделенный буфер реальным 
значением. 


Функция РЕСе'ЬЗеоЬіопНеідЪЕ — возвращает информацию о высоте ука¬ 
занной секции. Вызывается для совместной работы с функцией 
РЕСеіМіпітит8ес(:іопНеі§Ы; и должна быть использована при создании но¬ 
вого отчета. 


СипсСіоп РШеСЗесСіопНеідЬС ( 
ргіпЫоЪ: МогД; 
зесЬіопСойе: Зтаіііпі:; 


НеідЬС : ЗтаШпЕ 


): Вооі зЬДсаІІ? 


Параметры функции 

Описание параметров 

ргіпЬДоЬ 

Номер отчета, из которого запрашивается информация о 
высоте секции 

зесЬіопСоДе 

Код секции, который может быть получен с помощью 
функции РЕѲеІЗесІіопСоДе 

ЬеідЬЬ 

Высота секции 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСеъзеіесЪэсіРгіпЬэг — возвращает информацию о принтере, 
который в данный момент используется отчетом. 

іипсСіоп РЕѲеСЗеІесСеДРгіпЬег ( 
ргіпСДоЬ: МогД ; 
ѵаг ДгіѵегНапДІе: НМпД; 
ѵаг ДгіѵегЬепдЫі: МогД; 
ѵаг ргіпСегНапДІе: НИТіД; 
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ѵаг ргіпСегЬепдЫі: Мог<3; 
ѵаг рогСНапДІе: НИйй; 
ѵаг рогЬЬепдЬЬ: Иогсі; 
ѵаг шо<Зе: РІЗеѵі сѳМодеА 
): Вооі зМсаІІ; 


Параметры функции 

Описание параметров 

ргіпЬДоЬ 

Номер отчета, для которого необходимо получить ин¬ 
формацию о принтере 

йгіѵегНапйІе 

Указатель на драйвер принтера 

сігіѵегЬепдЫі 

Длина имени драйвера принтера 

ргіпСегНапсІІе 

Указатель на строку, содержащую имя принтера 

ргіпСегЬепдСЬ 

Длина строки, содержащей имя принтера 

рогЬНапсіІе 

Указатель на порт, к которому подключен принтер 

рогСЬепдЬЬ 

Длина имени порта 

то сіе 

Запись ОЕѴМСЮЕ, содержащая информацию о принтере 
(ѴѴІпсІоѵѵз АРІ) 

Возвращаемые значения 


□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Функция РЕбеЫЗеіесѣіопГогтиіа — возвращает указатель на строку, содер¬ 
жащую текст формулы, ограничивающей выборку данных в отчет. Исполь¬ 
зуйте РЕЗеЙеІесІіопРогтиІа для того, чтобы изменить формулу. 

ГипсЬіоп РЕѲеСЗеІесСіопРогтиІа ( 
ргіпЬЛоЬ: МогД; 
ѵаг СехСНапШе: НѴйкЗ; 
ѵаг ЬехЬЬепдЫі: Иогй 
): Вооі зЬЗсаІІ; 

Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором требуется проверить и, если 
потребуется, изменить формулу 

СехСНапсІІе 

Указатель на строку, содержащую текст формулы 

СехСЬепдЬЬ 

Длина строки, содержащей текст формулы, в байтах, 
включая завершающий байт 
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Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСеъздьЕхргеззіоп — возвращает указанное ЗС^Ь-выражение 
в выбранном отчете. 

ЕипсСіоп РЕОеЬЗОЬЕхргеззіоп ( 
ргіпЫоЪ: ЗтаІІіпС; 
сопзЬ ехргеззіопЛате: РСЬаг; 
ѵаг ЬехЬНапШе : НИпй; 
ѵаг СехСЬепдСЬ: Зтаіііпі 
): Вооі зЬйсаІІ; 


Параметры функции 

ргіпСДоЬ 

ехргеззіопЫате 

СехСНапДІе 

СехСЬепдЫі 


Описание параметров 

Номер отчета, из которого требуется извлечь 30І_- 
выражение 

Строка, содержащая имя выражения 

Указатель на строку, содержащую текст выражения 

Длина строки, содержащей текст выражения 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕбесздьоиегу — возвращает ЗС^Ь-запрос, с помощью которого 
в отчет извлекаются данные из источника. Используйте функцию 
РЕЗеіЗрьриегу для того, чтобы изменить запрос. 

СипсСіоп РЕСеСЗС!:ь<2иегу ( 
ргіпЫоЪ: Ногй; 
ѵаг ЬехСНапШе: НѴйкЗ; 
ѵаг ЬехСЬепдЬЬ: Ногй 
) : Вооі зЬсісаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, из которого требуется получить информа¬ 
цию о ЗОЬзапросе 

СехСНапШе 

Указатель на строку, содержащую 301-запрос 

ЬехСЬепдСЬ 

Длина строки, содержащей 801.-запрос, в байтах, с уче¬ 
том завершающего байта 
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Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


(_ Замечание ) 

Перед тем как вызывать функцию РЕСеіЗОЮиегу отчет должен быть подклю¬ 
чен к базе данных. 

Функция РЕееъзиЬгерогііп^о — возвращает информацию об указанном 
подотчете. 

СипсСіоп РЕСеСЗиЪгерогСІпіо ( 
ргіпЫЪЬ: НогЦ; 
зиЬгерог СНапсІІе : Шогй ; 
ѵаг зиЬгерогЬІпіо: РЕБиЬгерогсіпТо 
): Вооі зЬйсаІІ; 


Параметры функции 

ргіпрДоЬ 
зиЪгерогЬНапгіІе 


зиЬгерогСІпііо 


Описание параметров 

Номер отчета, который содержит требуемый подотчет 

Указатель на подотчет для которого требуется получить 
информацию 

Запись РЕЗиЬгерогІІпІо, которая используется для хране¬ 
ния возвращаемой информации 


Возвращаемые значения: 

□ ТКІШ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕОестгасксигзогіпго — возвращает информацию о типе курсора. 
Различные типы курсоров могут быть использованы для работы в разных 
областях отчета в режиме просмотра. 

НипсСіоп РЕѲеСТгаскСигзогІпіо ( 
ргіпЫоЬ: ЗтаІІігЛ; 


ѵаг сигзоПпЕо: 

) : Вооі зМсаІІ; 

РЕТгаскСигзогІпГо 

Параметры функции 

Описание параметров 

ргіпР ЛЪЬ 

Номер отчета , из которого необходимо получить инфор¬ 
мацию о типе курсора 

сигзогІпТо 

Запись РЕТгаскСигзогІпІо, которая будет содержать ин¬ 
формацию о типе курсора 
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Возвращаемые значения: 

П ТРШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕСеъѵегзіоп — возвращает номер версии ЭЬЬ или СгузіаІ КероП 
Епдіпе. Эта функция может быть использована тогда, когда требуется реали¬ 
зовать обработку отчетов, которые были сделаны в более ранних версиях 
СгузіаІ Керопз, и требуется уточнение. 

СипсСіоп РЕОеСѴегзіоп ( 

ѵегзіопКедиезСесІ: ІпСедег 
): ЕтаІІіпС зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ѵегзіопКедиезСесІ 

Определяет тип информации — версию ОН или СгузіаІ 
Нерогі Епдіпе требуется вернуть. Используются следую¬ 
щие константы: 

Константа РЕ_ѲѴ_ОІ_І_ 

Описание — возвращаемые значения: версия РИ 
(СЯРЕ/СЯРЕ32) 

Константа РЕ_(ЗѴ_ЕНСІНЕ 

Описание — возвращаемые значения: версия СгузіаІ Яе¬ 
рогі Епдіпе 


Возвращаемые значения: номер версии ЭЬЬ или СгузіаІ КероП Епдіпе. 


Функция РЕБеШіпсіоѵНапЦіе — возвращает указатель на окно просмотра 
отчета. Функция РЕСеІ\Ѵіпёо\ѵНапсі1е может быть использована для опреде¬ 
ления состояния отчета — открыт он или нет. 

НипсСіоп РЕСеШіпйоѵНапйІе ( 
ргіпЫоЪ: ИогЦ 
) : НМпй зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, для которого требуется получить инфор¬ 
мацию об указателе на окно просмотра. Если в момент 
вызова функции создано несколько окон просмотра, то 
возвращается информация об окне, созданном самым 


последним 
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Возвращаемые значения: 

□ указатель на окно просмотра — если отчет вызван без ошибок; 

□ О — если при вызове отчета возникла ошибка или окно просмотра уже 
закрыто. 

( Замечание ^ 

Эта функция может быть использована только после РЕЗіагІРгіпЫоЬ и в том 
случае, когда вы имеете созданное окно просмотра. 

Функция РЕСешішіоѵОреіопз — возвращает информацию о конфигурации 
окна просмотра отчета. 

СипсСіоп РШеШіпбомОрСіопз ( 
ргіпЫОЬ: Иогсі; 
ѵаг орЬіопз: РЕИіпдоѵЮр-Ьіопз 
):Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпС ДоЬ 

Номер отчета, который открыт в окне просмотра. Если в 
момент вызова функции открыто несколько отчетов на 
просмотр, то возвращается информация о последнем соз¬ 
данном окне 

РЕИіпсіомОрСіопз 

Запись РЕѴѴіпсіоѵЮрііопз, в которой будет содержаться 
информация об окне просмотра отчета 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

С Замечание ^ 

Когда значение ЬазСгоирТгее соответствует тгие, это не означает, что в окне 
просмотра откроется раздел дерева групп. Параметр ЬазСгоирТгее и свойст¬ 
ва отчета СгеаСе Сгоир Тгее в СгузСаІ КерогЬз должны совпадать, для 
того чтобы сделать видимым дерево групп в окне просмотра. 


Функция РЕНазЗаѵесШаЕа — возвращает информацию о наличии сохранен¬ 
ных данных в отчете. Используя эту информацию, вы можете определить, 
требуется обновление данных или нет перед тем, как отчет будет распечатан. 

ЁипсЬіоп РЕНазЗаѵесЮаСа ( 
ргіпЫоЪ: Иог<3; 
ѵаг ЬазЗаѵеДОаСа: Вооі 
): Вооі зЬЗсаІІ; 
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Параметры функции 

Описание параметров 


ргіпьлоЬ Номер отчета, в котором требуется определить наличие 

сохраненных данных 

ЪазЗаѵесШаСа Индикатор наличия или отсутствия сохраненных данных. 

ТЯІІЕ — если данные есть, РАІ.ЗЕ — если данных нет 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание } 

Отчет может иметь, а может и не иметь сохраненные данные перед печатью 
или просмотром, на момент печати или просмотра немедленно создается со¬ 
храненный набор данных. 

Используйте функцию РЕОіэсагсіЗаѵесІОаСа для того, чтобы освободить отчет 
от связанных с ним сохраненных данных. При последующих вызовах отчета 
данные будут всегда браться из базы, а не из сохраненных массивов. 


Функция РЕіаРгіпедоЬРіпізЬесі выполняет мониторинг отчета и отслежива¬ 
ет момент завершения работы над отчетом. 

СипсЬіоп РЕІзРгіпЬДоЬРіпізЬесі ( 
ргіпЫоЪ: Иогсі 
) : Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпСЛоЬ 

Номер отчета, который необходимо проверить 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( 


Замечание 



Функция РЕІзРгіпиоЬРіпізИеб вернет ТРШЕ сразу же после того, как отчет будет 
показан в окне просмотра, даже если окно просмотра все еще открыто. 
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Функция РЕЬодо^^зегѵег — позволяет выполнить отключение от указан¬ 
ного сервера. 

ЕипсСіоп РЕЬодОІІЗегѵег ( 
сШЫапіе: РСЬаг; 
ѵаг ІодОпІпіо: РЕЬодОпІпіо 
) : Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ЦЦЦате 

Имя библиотеки, используемой для подключения к ис¬ 
точнику данных 

ІодОпІпІо 

Запись РЕІ_одОпІФо, содержащая информацию о серве¬ 
ре, базе данных, имени и пароле пользователя 


Возвращаемые значения: 

□ ТРШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


(_ Замечание 

Функции РЕІ_одОпЗегѵег и РЕІ-одОШЗегѵег могут быть вызваны в любое время 
для подключения и отключения от сервера. Эти функции не потребуются, если 
будет обработана функция РЕЗеШФТаЫеІ-одОпІпІо. 

Данная функция требует имя библиотеки, используемой для подключения к ба¬ 
зе данных, которое может быть получено из функции РЕѲеШИТаЫеТуре. 


Функция РЕЬодОпзегѵег — используется для подключения отчета к источ¬ 
нику данных. 

ЕипсСіоп РЕЬодОпЗегѵег ( 

<31 ІЫате : РСЬах ; 

ѵаг ІодОпІп^о: РЕЬодОпІпіо 

): Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

сШЫате 

Имя библиотеки, используемой для подключения к источ¬ 
нику данных 

ІодОпІпіо 

Запись РЕІ_одОпІпк>, содержащая информацию о сервере, 
базе данных, имени и пароле пользователя 
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Возвращаемые значения: 

□ ТРШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 


(_ Замечание ) 

Функции РЕ1-одОп8егѵег и РЕ!-одО#Зегѵег могут быть вызваны в любое время 
для подключения и отключения от сервера. Эти функции не потребуются, если 
будет обработана функция РЕЗеШЩТаЫеІодОпІпІо. 

Данная функция требует имя библиотеки, используемой для подключения к ба¬ 
зе данных, которое может быть получено из функции РЕѲеШШТаЫеТуре. 

Эта функция может быть использована для любых типов источников данных. 

Когда отчет обрабатывается с помощью функции РЕЗІагІРгіпУоЬ, параметр 
ЗегѵегЫате, используемый в РЕІ-одОпЗегѵег, не требуется, так как он записан 
в самом отчете. Функция РЕІодОпЗегѵег может быть использована для пере¬ 
ключения отчета на другой сервер в момент вызова отчета из приложения. 

Особенности использования функций РЕІодОпЗегѵег и РЕЗеШІПТаЫеІ-одОпІпІо: 

• РЕІодОпЗегѵег вызывается раньше, чем РЕЗеШІКТаЫеІ_одОпІпІо, и может 
быть вызвана в любое время. Однако для ее работы необходимо знать имя 
библиотеки, через которую осуществляется подключение к серверу; 

• РЕЗеШІйТаЫеІ-одОпІпІо более гибкая, чем РЕІодОпЗегѵег. Она позволяет 
переопределить любые параметры подключения к базе данных. РЕ- 
ЗеІМІйТаЫеІ_одОІІпІо должна вызываться после РЕОрепРгіпУоЬ. 


ФуНКЦИЯ РЕЬодОпЗОЬЗегѵегНіЪЪРгіѵаЬеІпіо — ГфСДОСТаВЛЯеТ ВОЗМОЖНОСТЬ 

использовать уже существующее подключение к серверу. С помощью дан¬ 
ной функции можно снизить количество соединений с базой данных. 

НипсЬіоп РЕЬодОпздьзегѵегиіЬЬРгіѵаСеІпЕо ( 

(31 ІЫате : РСЬаг ; 
рг іѵаГеІпІо : РоіпРег 
): Вооі звЗсаІІ; 


Параметры функции 

Описание параметров 

сІІІЫате 

Имя библиотеки, используемой для подключения к источ¬ 
нику данных 

ргіѵаіеіпіо 

Указатель на соединение с базой данных. В приложении 
любое соединение с базой данных формирует указатель 
на соединение с базой данных (НОВО), содержащий всю 
необходимую для работы информацию. Этот параметр да¬ 
ет возможность отчетам СгузіаІ Нерогіз соединяться с ба¬ 
зой данных по уже существующим каналам 


13 Зак 1021 
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Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ^ 

Если приложение использует СЮВС для соединения с базой данных, получить 
СЮВС НОВО можно с помощью следующих функций (так же смотрите докумен¬ 
тацию по СЮВС): 

• 8<ЗІ_АІІосЕпѵ — выполняется инициализация СЮВС на уровне вызова и вы¬ 
деляется память для указателей; 

• ЗСЩАІІосСоппесІ — возвращается ООВС НЭВС. 


Функция РЕМех'ЬРгіп'ЬиіікЗоѵйМадпііісаЬіоп — используется для изменения 
размеров отчета в окне просмотра: Риіі Ра^е, Ріі Опе Зісіе, Ріі ВоіН ЗісЗез, апб 
Риіі Ра§е, Ріі Опе 8ісіе и т. д. Функция позволяет установить следующий по 
порядку уровень увеличения. 

іипсСіоп РШехСРгіпШіпсІоѵМадпіЕісаЬіоп ( 
ргіпЫоЪ: Иог<3 
) : Вооі зЬйсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, который открыт в окне просмотра, и требу¬ 
ется изменить его увеличение 


Возвращаемые значения: 

□ ТГШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕОрепЕпдіпе — подготавливает СгуБІаІ Кероіт Еп§іпе к обработке 
запросов. 

іипсьіоп РЕОрепЕпдіпе 
) : Вооі зЬЗсаІІ; 


Возвращаемые значения: 

□ ТШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 
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( Замечание ) 

Эта функция вызывается раньше, чем любая другая функция СгузіаІ Ріерогі 
Епдіпе. При возникновении ошибки в момент вызова функции РЕОрепЕпдіпе 
может быть использована функция РЕСеіЕггогСобе для вывода информации. 

Функция РЕОрепЕпдіпе инициализирует СгузіаІ Керогі Епдіпе в режиме оди¬ 
нарного потока (зіпдіе-ііігеаб). 


Функция РЕОрепРгіпЕіТоЪ — подготавливает отчет для последующей обра¬ 
ботки (просмотр, печать и т. д.) и — возвращает номер, который позволяет 
идентифицировать этот отчет, 
іипсеіоп РЕОрепРгіпЫоЪ ( 


герогОРіІеРаЫі : 

РСЬаг 

) : ВтаІІіігЬ зЬйсаІІ; 

Параметры функции 

Описание параметров 

герогЬРіІеРаЫі 

Путь и имя к файлу, который вы хотите открыть. Данный 
параметр записывается в двойных кавычках 


Возвращаемые значения: 

□ номер отчета или, по-другому, указатель на отчет. В других функциях 
используется как ргіпсдоь; 

□ О — если файла не существует или возникла ошибка при его обработке. 


С 


Замечание 


) 


Эта функция вызывается в большинстве случаев раньше, чем все остальные 
функции СгузіаІ Керогі Епдіпе. 

Одновременно можно обработать только один файл отчета. 

Функция РЕСІозеРгіпСоЬ должна быть вызвана для закрытия отчета. 

Путь к отчету и имя файла должны быть заключены в двойные кавычки: 

• РЕОрепРгіпЫоЬ ("С:\СКѴ\АКЕРОПТ1 .ПРТ"); 

• при использовании языков С или С++ значок \ в строке должен быть опре¬ 
делен как\\. 


Эта функция открывает отчет с указанием принтера, выбранного в отчете, или 
принтера, принятого по умолчанию. 


Функция РЕОрепЗиЬгерогЕ — открывает поименованный подотчет и воз¬ 
вращает идентификационный номер этого подотчета. 

іипсСіоп РЕОрепЗиЬгерогЬ ( 
рагепЫоЪ: Мог<3; 
зиЬгерогШаше: РСЬаг 
) : Иогй зСсІсаІІ; 
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Параметры функции Описание параметров 

рагепьлоь Номер отчета, который является основным по отношению к 

подотчету. Этот указатель возвращается функцией 
РЕОрепРгіпУоЬ 

зиЬгерогсыате Указатель на имя подотчета, который необходимо открыть. 

Эта информация может быть получена с помощью функ¬ 
ции РЕѲеіЗиЬгерогНпйэ 


Возвращаемые значения: 

□ номер обрабатываемого подотчета; 

□ О — если подотчет не существует или возникла ошибка при его обработке. 

Г Замечание _ ) 

Эта функция должна вызываться перед всеми другими функциями СгузіаІ 
Керой Епдіпе, которые обращаются к данному подотчету. 

Функция РЕСІозеЗиЬгерой используется для закрытия подотчета. 

Функция РЕОиСриЕтоРгіпЕег — отправляет подготовленный к работе отчет 
на выбранный принтер. 

^ипсСіоп РЕОиСриСТоРгіпСег ( 
ргіпЫоЬ: Иог<3; 
пСоріез : ІггЬедег 
) : Вооі зСсісаІІ ; 


Параметры функции 

Описание параметров 

ргіпс ДоЬ 

пСоріез 

Номер отчета, который необходимо распечатать 

Количество копий, которое необходимо распечатать. Ука¬ 
жите 0 для того, чтобы использовать установки по умолча¬ 
нию 


Возвращаемые значения: 

□ ТКЕІЕ — если вывод на принтер выполнен корректно; 

□ РАЬЗЕ — если отчет не может быть выведен на принтер. 

( Замечание } 


Если принтер был установлен с помощью функции РЕЗеІесіРгіпІег, отчет будет 
отправлен на этот принтер. 
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Если функция РЕЗеІесіРгіпіег не выполнялась, отчет будет отправлен на тот 
принтер, который указан непосредственно в самом отчете. 

Если функция РЕЗеІесіРгіпіег не выполнялась и в отчете не прописан принтер, 
то отчет будет выведен на тот принтер, который определен в ѴѴіпйоѵѵв как 
принтер по умолчанию. 

Набор функций, которые помогут вывести отчет на принтер: 

• РЕОрепРгіпУоЬ — открывает отчет; 

• РЕОиіриіТоѴѴіпсІоѵѵ — выводит отчет в окно просмотра с заданием пара¬ 
метров окна; 

• РЕЗіагІРгіпЫоЬ — выводит отчет в окно просмотра с параметрами по умол¬ 
чанию; 

• РЕОиІриІТоРгіпІег — выводит отчет непосредственно на принтер; 

• РЕЗеІесіРгіпіег — позволяет переопределить ранее выбранный принтер; 

• РЕЗіагІРгіпУоЬ — после смены принтера открывает окно просмотра отчета 
с новыми настройками; 

• РЕСІозеРгіпУоЬ — закрывает отчет. 


Функция РЕОиЪриЕТоИіпдо» — направляет отчет непосредственно в окно 
просмотра. 

СипсСіоп РЕОиСриСТоИіпсІоѵ ( 
ргіпСДоЬ: МогЦ; 

СІСІе: РСЪаг; 

ІеСС: ІюпдіпЬ; 

Сор: ІюпдіпЬ; 
тбСЬ : ІюпдіпЬ ; 

ЬеідЬС: ІюпдіпЬ; 

5 Су1е: ІюпдіпЬ; 
рагепШіпсЗото: НИпсі 
) : Вооі 5С<Зса11; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, который необходимо просмотреть перед 
печатью 

СіСІе 

Строка, содержащая текст, который должен появиться в 
заголовке окна просмотра 

ІеСС 

Абсцисса верхнего левого угла окна просмотра в пикселах 

Сор 

Ордината верхнего левого угла окна просмотра в пикселах 

ѴІСІСІ1 

Ширина окна просмотра в пикселах 

ЬеідЬС 

Высота окна просмотра в пикселах 
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(продолжение) 

Параметры функции Описание параметров 

зьуіе Стиль окна, которое будет создано. При формировании 

стиля можно пользоваться комбинацией констант, объеди¬ 
ненных оператором ОВ: 

Константа из_міыімі 2 е 
Значение 536870912 

Описание: создается окно минимального размера 
Константа из_ѵізівье 
Значение 268435456 

Описание: окно становится видимым сразу же при вызове 
функции 

Константа из_оізавьео 
Значение 134217728 

Описание: окно становится недоступным для любых воз¬ 
действий 

Константа из_сцірзівыысз 

Значение 67108864 

Описание: закрепляется как дочернее окно относительно 
другого окна 

Константа из_сырсніілжеы 

Значение 33554432 

Описание: исключается область дочернего окна, попа¬ 
дающая при прорисовке за рамки родительского 
Константа кз_махімі2е 
Значение 16777216 

Описание; создается окно максимального размера 
Константа из_сартіоы 
Значение 12582912 

Описание: создается окно, содержащее панель заголовка 
Константа из_вокоек 
Значение 8388608 

Описание: создается окно, окруженное рамкой 
Константа из_оьсекаме 
Значение 4194304 

Описание: создается окно, окруженное двойной рамкой и 
не имеющее панели заголовка 
Константа кз_ѵзскоьь 
Значение 2097152 

Описание: создается окно, которое содержит панель вер- 
_тикального скроллинга_ 
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(окончание) 

Параметры функции Описание параметров 



зьуіе Константа из нзскоьъ 


Значение 1048576 

Описание: создается окно, которое содержит панель гори¬ 
зонтального скроллинга 

Константа из_зузмеот 

Значение 524288 

Описание: добавляет в окно панель системных кнопок и 
меню 

Константа из_тніскреаме 

Значение 262144 

Описание: включается широкая рамка, используемая для 
изменения окна просмотра 
Константа из_міыімі2евох 
Значение 131072 

Описание: добавляется кнопка минимизации 
Константа из_махімі2евох 
Значение 65536 

Описание: добавляется кнопка максимизации 
Константа си_іізевгаі)ьт 
Значение-32768 

Описание: устанавливаются параметры, соответствующие 
значениям по умолчанию для дочерних окон 

рагепдиіпсіоѵ Указатель на родительское окно, которое выступает носи¬ 

телем окна просмотра 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

С Замечание ^ 

Для самостоятельного окна просмотра верхний левый угол определяется отно¬ 
сительно всего экрана. Для дочернего окна в приложении мЬі верхний левый 
угол определяется относительно рабочей области главного окна приложения. 
Для окна просмотра, которое использует в качестве подложки другое окно, 
верхний левый угол определяется относительно этого окна. 

Если параметр рагепсиіпсіоѵ равен N1111, окно просмотра является само¬ 
стоятельным окном верхнего уровня, которое не может быть дочерним по 
отношению к другим окнам. Для такого варианта окна просмотра можно 
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использовать константу СК^цзоераЬ'ЬТ, чтобы расположить его в рамки, за¬ 
данные по умолчанию, 

Если в качестве родительского окна определено главное окно МЭІ-приложения, 
то окно просмотра будет выведено как дочернее в рабочую область родитель¬ 
ского окна, 

Если параметр рагепсиіпРоѵ указывает на любое другое окно приложения, то 
окно просмотра становится дочерним для этого окна и размещается внутри него. 

Если окно просмотра является самостоятельным или дочерним по отношению 
к главному окну МОІ-приложения и параметр $(уІе равен 0, то этот стиль заме¬ 
няется по умолчанию на следующую комбинацию стилевых констант: 

(№5_ѴІ5ІВЬЕ | И5_ТНІСКРКАМЕ | ИЗ_5УЗМЕШ | ИЗ_МАХІМІ2ЕВОХ | 
ВД5_МІЫІМІ2ЕВОХ) 

Эти параметры являются параметрами по умолчанию для любых окон 
в ѴѴІпбоѵѵз. 

Окно просмотра создается после вызова функции РЕЗІаіІРгіпШЬ. 


Функция РЕРгіпЕСопЕгоіззЪоѵіпд — определяет наличие кнопок, позволяю¬ 
щих выполнять печать и настраивать принтер в окне просмотра отчета. Эта 
функция используется совместно с резЪомРгіпьсопЬгоі в для изменения ви¬ 
димой комбинации кнопок в окне просмотра отчета. 

іипсСіоп РЕРгіпсСопСгоІзЗІіо'міпд ( 
рГІПСЛоЬ : МогЦ; 
ѵаг сопегоІзЗЬоѵіпд: Вооі 
) : Вооі зесісаіі; 


Параметры функции 

Описание параметров 

ргіпСЛоЬ 

Номер отчета, который отображен в окне просмотра, и тре¬ 
буется изменить комбинацию кнопок управления в этом 


окне 

сопСгоІзЗЬоміпд 

Флаг отображения контрольных кнопок. Если ТРШЕ, то 
кнопки отображены, если РАІ.8Е, то кнопки скрыты 


Возвращаемые значения: 

□ ТКЕІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕРгіпЕКероге — выполняет печать указанного отчета либо на 
принтер, либо вывод отчета в окно просмотра. 

іипсСіоп РЕРгіпСКерогС ( 
герогСРіІеРаЫі: РСЬаг; 
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СоВе^аиІСРгіпСег : Вооі; 

Соиіпсіом: Вооі; 

ЬіЫе: РСЬаг; 

ІеіШ: ІпЪедег; 

Сор: ІпЪедег; 

Ѵ7ІЙ1:І1 ; ІпЪѳдег ; 

ЬеідЫ: ; ІпЪедег ; 
зСуІе: ЬопдіггЬ ; 
рагепШіпсіом: НИпй 
) : БтаШпе зрйсаіі; 

Параметры функции 

Описание параметров 

герогЬРіІеРась 

Строка, завершающаяся на ШИ и содержащая пути и 
имя файла отчета, который необходимо распечатать 

РоОеіаиІРРгіпрег 

Флаг вывода на принтер по умолчанию 

СоИіпсІои 

Флаг вывода в окно просмотра 

ІіЫе 

Строка, содержащая текст заголовка для окна просмотра 
отчета 

ІеСС 

Абсцисса верхнего левого угла окна просмотра отчета в 
пикселах 

сор 

Ордината верхнего левого угла окна просмотра отчета в 
пикселах 

ѵісісъ 

Ширина окна просмотра отчета в пикселах 

ЬеідЬС 

Высота окна просмотра отчета в пикселах 

зСуІе 

Стиль окна, которое будет создано. Формируется анало¬ 
гично стилю, определяемому в функции 

РЕОиіриіТоѴѴІпсіоѵѵ 

рагепСВДіпсІом 

Указатель на родительское окно, которое выступает но¬ 
сителем окна просмотра 


Возвращаемые значения: 

□ РЕ_ЕКК_МОЕІІІІ(Ж — если отчет обработан без ошибок; 

□ код ошибки, если отчет обработан с ошибками. 


Функция РЕРгіпШігШои — вывод отчета в окно просмотра. 

іипсЬіоп РЕРгіпШіпйоод ( 
ргіпЫоЪ: Иогй; 
тоаіСЦпСі ІЦопе : Вооі 
) : Вооі зСсІсаІІ; 
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Параметры функции 

Описание параметров 

ргіпСДоЪ 

«аіСЦпСіЮопе 

Номер отчета, который необходимо вывести в окно про¬ 
смотра 

Этот параметр является зарезервированным и всегда дол¬ 
жен быть ТВУЕ 


Возвращаемые значения: 

□ ТИПЕ — если вызов удачен; 

□ РАЬ8Е — если вызов неудачен. 


Функция РЕКеішрогезиЬгерог'Ь — переносит подотчет в указанный отчет. 

йдпсСіоп РЕКеітрогСЗиЪгерогІ: ( 
ргіпЫоЪ: Иогд; 
зиЪгерогДНапдІе : ОИогЦ; 

1 іпкСЦапдеД : Вооі; 
геіпрогьеД: Вооі 
) : Вооі 5(:<3са11; 


Параметры функции 

ргіпСДоЪ 

зиЪгерогСНапсІІе 

ІіпкСЬапдесі 

геітрогресі 


Описание параметров 

Номер отчета, который является основным 

Номер подотчета, который требуется перенести 

Флаг, определяющий необходимость изменения взаимо¬ 
связей 

Флаг, определяющий необходимость переноса подотчета 


Возвращаемые значения: 

□ ТІШЕ — если вызов функции произошел без ошибок и подотчет обнов¬ 
лен или перенесен с фиксацией изменений в связях; 

□ РАЬЗЕ — если функция вызвана с ошибкой. Путь к подотчету неверен 
или перенос невозможен. 


( Замечание ) 

Параметр ІіпкСМапдеЦ будет равен: 

• РА!_8Е, если подотчет перезагружен и связи зафиксированы; 

• ТКУЕ, если подотчет перезагружен, но связи неверны. 
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Параметр геітрогіесі будет равен; 

• РАІ.ЗЕ, если подотчет обновлен или перезагружен с неверным путем или 
с другой ошибкой; 

• ТКІІЕ, если подотчет перезагружен с фиксацией связей либо с их ошибкой. 


Функция РЕЗеіес-ьргіпіег — позволяет указать принтер, отличный от того, 
который определен в отчете или является принтером по умолчанию 
в \Ѵ'І ПСІОѴ/5. 

Еипсеіоп РЕЗеІесСРгіпСег ( 
ргіпСіТоЪ: ИогЦ ; 
дгіѵегЫате: РСЬаг; 
ргіпСегЫате: РСЬаг; 
рогЬЫате: РСЬаг; 
то<Зе: РОеѵісеМойѳА 
) : Вооі зСсІсаІІ; 


Параметры функции 

Описание параметров 

ргіпі: ДоЪ 

Номер отчета, для которого требуется сменить принтер 

СігіѵегЦате 

Строка, содержащая имя драйвера принтера, завер¬ 
шающаяся ЫІЛй 

ргіпСегЦате 

Строка, содержащая имя принтера, завершающаяся 
N111.1- 

рогСЫате 

Строка, которая содержит имя порта, используемого 
принтером, завершающаяся N1)11 

тосіе 

Запись ОЕѴМСЮЕ, которая относится к записям ѴѴіпсіоѵѵз 
АРІ 


Возвращаемые значения: 

□ тіше — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеЬАііоиРготрідэіаіод — определяет необходимость отображе¬ 
ния диалога, предлагающего ввести значения параметров в момент печа¬ 
ти отчета. 

ГипсСіоп РЕЗеСАНовдРготрЬОіаІод ( 
рГІпСДоЬ: ЗтаІІіггЬ; 
зЬоі/ѵРготрЮіаІод: Вооі 
) : Вооі зСсісаІІ; 
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Параметры функции Описание параметров 

ргіпедоЪ Номер отчета 

зЬоиРготрьОіаІод Равен ТНІІЕ, когда изменение значений параметров 

возможно 


Возвращаемые значения: 

□ ткиЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеъАгеаЕ’огшаЪ — позволяет установить параметры форматиро¬ 
вания для выбранной секции отчета. Эта функция является аналогом функ¬ 
ции РЕОеіАгеаРогпш, имеет тот же синтаксис и особенности применения. 

ГипсСіоп РЕЗеСАгеаРогшаС ( 
ргіпЫоЪ: ИогЦ 
агеаСосіе : ІпСѳдег ; 
орЬіопз : РЕЗесЬіопОрЫопа 
): Вооі з сДса 11; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в который необходимо передать параметры 
форматирования 

агеаСосіе 

Специфические коды разделов, для которых необходимо 
установить параметры форматирования, с помощью констант: 

РЕ_АЫ,5ЕСТІ0№ 

РЕ_8ЕСТ_РАСЕ_НЕАБЕК 

РЕ_5ЕСТ_РАСЕ_РООТЕК 

РЕ_5ЕСТ_КЕРОКТ_НЕАОЕК 

РЕ_5ЕСТ_КЕР0КТ_Р00ТЕК 

Р Е_3 ЕС Т_СЖОЦР_НЕ АО ЕК 

Р Е_3 ЕСТ_СКОЦР_РООТЕН 

РЕ_ЗЕСТ_БЕТАІЬ 

орсіопз 

Запись РЕЗесііопОрііопз, которая будет содержать ин¬ 
формацию о параметрах форматирования выбранного 
раздела отчета 


Возвращаемые значения: 

□ Т(ШЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 
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Функция РЕЗеЪАгеагогтааъгогтціа — позволяет изменить формулу форма¬ 
тирования выбранной секции отчета. Эта функция позволяет изменить текст 
только у существующей формулы. Добавить новую формулу с ее помощью 
невозможно. 

СипсСіоп РЕЗеиУгеаРогтаСРопшІа ( 
ргіпЫЪЬ: Йога; 
агеаСосІе : Иогй; 

СогтиІаШте: Иогй; 

СогтиІаЗЛгіпд: РСЬяг 
) : Вооі 5 Ьсіса 11; 


Параметры функции Описание параметров 

ргіпеЛоЪ Номер отчета, для которого необходимо изменить фор¬ 

мулу форматирования раздела 

агеаСоЦе Специфические коды разделов, для которых необходимо 

изменить параметры форматирования, задаются кон¬ 
стантами: 

РЕ_АЬЬ5ЕСТІО№ 

РЕ_ЗЕСТ_РАСЕ_НЕАОЕК 

РЕ_ЗЕСТ_РАСЕ_Р00ТЕК 

РЕ_3ЕСТ_КЕ РОКТ_НЕАЕЕК 

РЕ_ЗЕСТ_КЕРОНТ_РООТЕК 

РЕ_ЗЕСТ_СКОЦР_НЕАСЕК 

РЕ_ЗЕСТ_ОКОЦР_РООТЕК 

РЕ_ЗЕСТ_БЕТАІЬ 

іогтиІаЫате Константа, определяющая имя формулы форматирова¬ 

ния, в которую вы хотите записать новую строку: 

РЕ_Р РКЩАКЕА8ЕСТІ ОКГ_ѴІ 31ВIЫ ТУ 

РЕ_РРЦ_5ЕСТІ(Ж_ѴІ8ІВІЬІТУ 

РЕ_РРЦ_ЗНОМ_АКЕА 

РЕ_РРЦ_ЦЕИ_РАСЕ_ВЕРОКЕ 

РЕ_РРЦ_ЦЕИ_РАСЕ_АРТЕК 

РЕ_РРЦ_КЕЕР_ТОСЕТНЕК 

РЕ_РРН_ЗЦРРНЕ55_ВЬАт_ЗЕСТІ0Ы 

РЕ_РРЦ_КЕЗЕТ_РАСЕ_Ы_АРТЕК 

РЕ_РРЦ_РК1ЫТ_АТ_В0ТТ0М_0Р_РАСЕ 

РЕ_РРЫ_тГОЕНЬАУ_5ЕСТІ0Ы 

РЕ_РРЫ_ЗЕСТ10Ц_ВАСК_С0Ь0ЦН 

РЕ_РРЦ_ЗЕСТІ0Ц_ВАСК_С0Ь0К 

іогтиіазсгіпд Строка, которая содержит текст формулы форматирова¬ 

ния, завершающаяся значением N1)1.1- 
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Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен; 

□ код ошибки РЕ_ЕК.К_ВАОРОН.М1ЛАНАМЕ, если формула не существует; 

□ код ошибки РЕ_ЕВВ_ВАОРОВМШАТЕХТ, если есть ошибка в формуле. 

( Замечание ) 

Эта функция вызывается перед РЕЗІаі-ІРгіпУоЬ, иначе результат может быть 
неверным. Не все параметры могут быть использованы в любых разделах 
отчета. 


Функция РЕЗеепіаіодРагепШіпаоѵ — устанавливает ссылку на родитель¬ 
ское окно, в котором открывается отчет. 

ГипсСіоп РЕЗ е ЬО іа 1 од Ра г еп Ш іпсіоѵ ( 
ргіпЫоЪ: МогЦ; 
рагепШіпсІоад: ннпсі 
): Вооі зСйсаІІ; 


Параметры функции Описание параметров 

ргіпЫоЪ Номер отчета, для которого необходимо установить 

родительское окно 

рагепсиіпсіоѵ Указатель или ссылка на родительское окно 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеЪЕѵепССаііЪаск — определяет функцию обратной связи для 
выбранного отчета. Сгузіаі Верой Еп§іпе может сформировать событие, ко¬ 
гда что-то произойдет внутри области действия Сгузіаі Верой Еп§іпе. СВРЕ 
вызовет функцию обратной связи и произведет уведомление о том, какого 
рода событие произошло. С помощью функции саііЪаскРгос пользователь 
может обработать событие по его идентификатору и выполнить надлежащие 
операции. 

ГипсСіоп РЕЗеЬЕѵепССаІІЬаск { 
ргіпЬДоЪ: Иогй; 
саІІЬаскРгос: Роіпіег 
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{Функция обратной связи должна быть представлена в виде: 
Рипссіоп саІіЬасРгос (еѵепЫБ: 5та11іггЬ; 
рагалѵ. РоіпЬег; 
изегБаЬа: РоіпРег)} 

) : Вооі збсісаіі; 


Параметры функции 

Описание параметров 

ргіпбДоЬ 

Номер отчета, для которого создается процедура обратной 
связи, обрабатывающая событие 

саІІЬаскРгос 

Процедура обратной связи, которая будет обрабатывать 
события Сгузіаі Яерогі Епдіпе. Она должна совпадать со 
стандартной процедурой обратной связи ѴѴіпсіоѵѵз. Описа¬ 
ние методов создания процедур обратной связи представ¬ 
лено в ѴѴіпсіоѵѵз ЗОК 

изегБаба 

Указатель на информацию, которую необходимо передать 
в процедуру обработки обратной связи. Это значение мо¬ 
жет быть равным 0 


Возвращаемые значения: 

□ тіше — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ) 

Каждый отчет может иметь только одну функцию обратной связи. 

Если саІІЬаскРгос вернула ТРШЕ, то действие по умолчанию для Сгузіаі 
КероП Епдіпе произошло. Если саІІЬаскРгос вернула РАІ.ЗЕ, то действие, 
определенное по умолчанию, не было использовано. Пользователь должен 
обеспечить какое-либо поведение приложения. Для некоторых событий значе¬ 
ние, возвращаемое саІІЬаскРгос, игнорируется. Для уточнения списка собы¬ 
тий, поддерживаемых СР?РЕ, необходимо обратиться к документации. 


Функция РЕЗеЕРіеіамарріпдТуре — устанавливает тип планировки полей 
для указанного отчета. 

ГипсЬіоп РЕЗеЬРіеІбМарріпдТуре ( 
ргіпЬОЪЬ; ЗтаІІіітЬ; 
ѵаг тарріпдТуре: Иог<3 
) : Вооі збсісаіі; 
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Параметры функции Описание параметров 

ргіпсЛоЬ Номер отчета, в котором необходимо изменить тип плани¬ 

ровки полей 

тарріпдтуре Константа соответствующего типа РЕ_РМ_ХХХ: 

РЕ_РМ_АЦТО_РЪБ_МАР 

РЕ_РМ_СКРЕ_РНОМРТ_РЬО_МАР 

РЕ_РМ_ЕѴЕ№Г_ОЕРШЕЦ_РЬО_МАР 


Возвращаемые значения: 

□ ТКЕІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕзесЕопе — устанавливает шрифт для поля или текстового блока 
в указанной секции отчета. 

СипсСіоп РЕЗеСРопС ( 
ргІпСЛоЬ: МогЦ; 
зесС іопСойе : ІпСедег ; 

3 соресойе : ІпСедег ; 
і асеКаше: РСЬаг; 

ГопСРаггііІу ; ІпСедег ; 

ЕопСРіСсЬ: ІпСедег; 
сйагЗеС: ІпРедег, 
роіпсЗіге: ІпСедег; 
ізІРаІіс: ІпСедег; 
ізЦпсІегІіпесІ: ІпСѳдег; 
ізЗСгискОиС: Іпредег; 
вдеідЬС: іпСедег 
): Вооі зСДсаІІ; 


Параметры функции 

Описание параметров 

ргіпСЛоЬ 

Номер отчета, в котором требуется изменить шрифт объ¬ 
екта 

зесСіопСосІе 

Код секции, для которой необходимо выполнить измене¬ 
ние шрифта. Используются константы, аналогичные кон¬ 
стантам, используемым в функциях РЕЗеіАгеаРогтаІ и 
РЕОеіАгеаРогтаІ 

зсореСосіе 

Константа, которая указывает, в каких элементах секции 
необходимо изменить шрифт (для того чтобы указать оба 
типа, необходимо использовать оператор ОЯ): 


Константа ре_ріеьоз 
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(продолжение) 

Параметры функции Описание параметров 

зсореСосіе Описание: устанавливает шрифт по умолчанию для всех 

полей в указанной секции отчета 
Константа ре_техт 

Описание: устанавливает шрифт по умолчанию для всех 
текстовых объектов, которые не были вставлены как поле, 
в указанной секции отчета 

басеыате Имя шрифта, который необходимо использовать. Напри¬ 

мер Тітез Ыеѵѵ Яотап. Установите 0, если не требуется 
изменять шрифт 

бопсгатііу Константа, определяющая семейство шрифтов: 

Константа рг_ооытсаке 
Описание: не менять 
Константа ее_комаы 

Описание: шрифт с переменной высотой — зегіі 
Константа ГГ_5йІ53 

Описание: шрифт с фиксированной высотой — ѵѵіііюиі 
зегііз 

Константа ее_мсюекы 

Описание: шрифт с фиксированной высотой — ѵѵіііі ог ѵѵіііі- 
оиі зегііз 

Константа ре_зскірт 

Описание: шрифт, подобный рукописному 

Константа ее_оесокатіѵе 

Описание: декоративный шрифт 

бопСРіСсЪ Константа, определяющая высоту шрифта: 

Константа оераііьт_рітсн 
Значение — 0X00 
Константа ріхео_рітсн 
Значение — 0X01 
Константа ѵакіавье_рітсн 
Значение — 0X02 

сЬагЗес Константа, определяющая тип кодировки, который будет 

использован: 

Константа аызі_снакзет 

Значение — 0 

Константа оерацьт_снакзет 

Значение — 1 _ 
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(продолжение) 

Параметры функции Описание параметров 


сЬагЗеб 


роіп-ЬЗіге 

ізІ'ЬаІіс 

ізОпсіегІіпесі 

ізЗРгискОиЬ 

ѵеідЫ; 


Константа зумвоь_снакзет 

Значение — 2 

Константа знірглз_снакзет 

Значение — 128 
Константа нашей ь_снакзет 

Значение — 129 

Константа сніыезевіс5_снакзет 

Значение — 136 
Константа оем_снакзет 

Значение — 255 

Определяет желаемую высоту шрифта. Установите 0, если 
не требуется вносить изменения 

ТЯІІЕ для наклонного шрифта, РАІ_ЗЕ для обычного и 
РЕ_ШСНАЫѲЕО для того, чтобы использовать текущие 
установки 

ТНІІЕ для подчеркнутого шрифта, РАІ_ЗЕ для обычного и 
РЕ_1ЛМСНАМ(ЗЕ0 для того, чтобы использовать текущие 
установки 

ТЯІІЕ для перечеркнутого шрифта, РАІ_5Е для обычного и 
РЕ_1)І\ІСНА^ ЕО для того, чтобы использовать текущие 
установки 

Константа, определяющая толщину шрифта (установите О, 
если не требуется вносить изменения): 

Константа еи_ооотсаке 
Значение — О 
Константа еи_тнш 
Значение — 100 
Константа ги_ехткаы6НТ 
Значение — 200 
Константа ги_ыснт 
Значение — 300 
Константа ги_шкмаь 
Значение — 400 
Константа ейммеоіш 
З начение — 500 
Константа еи_земівоьо 

Значение — 600 _ 
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(окончание) 

Параметры функции Описание параметров 

Константа еи_бош 
Значение — 700 
Константа еи_ехтвабош 
Значение — 800 
Константа ек_неаѵу 
Значение — 900 
Константа еи_щ,ткаЫ6НТ 
Константа еи_ехткаыснт 
Константа еи_ке<зцьак 
Константа ЕИ_ыокмдь 
Константа еи_оемівоьо 
Константа ри_земівош 
Константа е’и_ціл , кавоіщ 
Константа еи_ехткавош 
Константа ек_вьаск 
Константа ги неаѵу 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗе^Еогтиіа — позволяет изменить текст выбранной формулы. 
Эта функция изменяет только текст уже существующих в отчете формул. Вы 
не можете добавить новую формулу. 

СипсСіоп РЕЗеСРогтиІа ( 
ргіпЫоЪ: ИогЦ; 

ЕогшиІаМаіпе: РСЪаг; 

ЕоппиІаЗЬгіпд: РСЬаг 
) : Вооі зСйсаИ; 


Параметры функции 

Описание параметров 

ргіпРДоЬ 

Номер отчета, в котором необходимо изменить текст формулы 

ЕогтиІаЦате 

Строка, завершенная ШИ, содержащая имя изменяемой 
формулы 

СогтиІаЗТгіпд 

Строка, завершенная ЫІ)І_І_, содержащая новый текст 
формулы 
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Возвращаемые значения: 

□ ТГШЕ — если вызов удачен; 

□ РАЬБЕ — если вызов неудачен; 

□ код ошибки РЕ_ЕК.К._ВАОРОК.МУЬАЫАМЕ, если формула не сущест¬ 
вует; 

□ код ошибки РЕЕККВАОРСЖІѴШЕАТЕХТ, если в формуле есть син¬ 
таксическая ошибка. 


Функция РЕЗесЕ’огшиіаЗупі.ах — устанавливается тип синтаксиса формул 
для использования при обработке отчета с помощью функций АРІ. 

ргосесіиге РЕЗеСРогтиІаЗупСах ( 
ргіпЫоЬ: Могд; 

ѵаг ЁогшиІаЗупСах: РЕЕогтиІаЗупСах 
) : Вооі зСсісаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором необходимо изменить тип син¬ 
таксиса для формулы 

СогтиІаЗупСах 

Запись РЕРогтиІаЗупІах, которая будет содержать пере¬ 
даваемую информацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЫВЕ — если вызов неудачен. 


Функция РЕЗесегарЬАхізіпго — позволяет установить параметры осей у 
графика в отчете. 

ЕипсСіоп РЕЗеЬОгарЬАхізІпЕо ( 
ргіпЬДоЬ : Иог<2; 
зесЬіопІ'І : ЕшаІІіпС ; 
дгарЬЫ : ЕшаІІіпС; 


ѵаг дгарЬАхізІп^о 

: РЕОг арЬАхізІпТо 

) : Вооі зСсісаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором требуется установить параметры 
осей у графика 
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(окончание) 


Параметры функции 

Описание параметров 

зесЫопЫ 

Номер секции, в которой находится график, требующий 
установки параметров для осей. Этот параметр должен 
попадать в диапазон значений, возвращаемых функцией 
РЕѲеіЫЗесІіопз 

дгарЬЫ 

Номер графика, который необходимо настроить в указан¬ 
ной секции. Нумерация графиков начинается с 0 и основа¬ 
на на порядке вставки графика в отчет 

дгарЬАхізІп^о 

Запись РЕѲгарІіАхізІпк), которая содержит новую инфор¬ 
мацию 

Возвращаемые значения: 

□ ТК.ІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Функция РЕЗессгарЬРопеіпДо — позволяет установить шрифт для выбран¬ 
ного графика. 

Сипссіоп РЕЗеСОгарМ’опЫпЁо ( 
ргіпЫоЬ : МОГ<3; 
зесГіопН : ЕтаІІіпС; 
дгарШ : ЕтаІІіпС ; 

СіСІеРопСТуре : Иогй; 

ѵаг ГопЬСоІоигІпГо : РЕЕоіЛСоіогіпГо 

): Вооі зЫсаІІ; 

Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором требуется изменить шрифт для 
графика 

зесТіопИ 

Номер секции, в которой находится график. Этот параметр 
должен попадать в диапазон значений, возвращаемых 
функцией РЕОеШЗесШэпз 

дгарЬИ 

Номер графика, который необходимо настроить в указан¬ 
ной секции. Нумерация графиков начинается с 0 и основа¬ 
на на порядке вставки графика в отчет 

СіЫеРопЬТуре 

Используются одна из констант: 

Константа ре_стр_тітьероыт 

Описание: шрифт основного заголовка графика 

Константа ре_стр_5цвт1ТЬЕроыт 

Описание: шрифт подзаголовка 
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Приложение 1 
(окончание) 


Параметры функции Описание параметров 

ьіЫеГопьтуре Константа ре_стр_роотштегс»іт 

Описание: шрифт ссылки 
Константа ре_стр_ѳкоцрзтітьеромт 
Описание: шрифт заголовка группировки 
Константа ре_отр_оататітьероыт 
Описание: шрифт заголовка таблицы данных 
Константа РЕ_етр_ЬЕаЕЖ>РОМТ 
Описание: шрифт легенды 
Константа ре_стр_скоцрьавеьзроыт 
Описание: шрифт ярлыка для группировки 
Константа ?е_стр_оатаі,авеьзроыт 
Описание: шрифт ярлыка для таблицы данных 

іопьсоІоигІпСо Запись РЕРопІСоІоигІпІо, которая будет содержать новую 

информацию 

Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Функция РЕЗеесгарЬореіопіп^о — позволяет установить параметры отобра¬ 
жения указанного графика. 

ЕипсСіоп РЕЗеСОгарДОрЬіопІпЕо ( 
ргіпДТоЪ : Иогй; 
зесГіогЩ : Етаіііпе; 
дгарШ : БтаІІіпЬ; 

ѵаг дгарДОрГіопІпЕо : РЕСгарЬОрЬіопІпЕо 
): Вооі звЗсаІІ; 

Параметры функции Описание параметров 

ргіпрДоЬ Номер отчета, в котором необходимо установить парамет¬ 

ры отображения графика 

зесгіопм Номер секции, в которой находится график. Этот параметр 

должен попадать в диапазон значений, возвращаемых 
функцией РЕОеШЗесііопз 









Список функций СгузіаІ Иерогі Ргіпі Епдіпе АРІ 


401 


(окончание) 


Параметры функции Описание параметров 

дгарпм Номер графика, который необходимо настроить в указан¬ 

ной секции. Нумерация графиков начинается с 0 и основа¬ 
на на порядке вставки графика в отчет 

дгарЪОрсіопіпСо Запись РЕОгарЬОрііопІпіо, которая будет содержать новую 
информацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


ФУНКЦИЯ РЕЗеССгарЬТехШеДаиіСОрСіоп — ПОЗВОЛЯеТ ВКЛЮЧИТЬ ИЛИ ОТКЛЮ¬ 
ЧИТЬ текстовые заголовки графика, заданные по умолчанию. 

Сипсеіоп РЕЗесОгарЮехЫЗеЁаиіеОрСіоп ( 
ргіпСДоЬ : Ѵ/ог<3 ; 
зесСіопЫ : Етаіііпе,- 
дгарШ : ВтаШпЬ; 

СіСІеТуре : Иогсі; 
изеЮебаиІІ: ; Вооі 
): Вооі зСйсаІІ; 


Параметры функции 

Описание параметров 

ргіпрДоЬ 

Номер отчета, в котором необходимо выполнить настройку 
графика 

зесСіопЫ 

Номер секции, в которой находится график. Этот параметр 
должен попадать в диапазон значений, возвращаемых 
функцией РЕѲеІЫЗесІіопз 

дгарЬИ 

Номер графика, который необходимо настроить в указан¬ 
ной секции. Нумерация графиков начинается с 0 и основа¬ 
на на порядке вставки графика в отчет 

СіСІеТуре 

Тип заголовка. Используются константы: 

Константа ре ѳтт_тітье 

Описание: основной заголовок графика 

Константа ре_стт_зцвтітье 

Описание: подзаголовок графика 

Константа ре стт_гоотмоте 

Описание: сноска 

Константа ре_ѳтт_зекіезтітье 
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Приложение 1 
(окончание) 


Параметры функции Описание параметров 

ТіСІеТуре Описание: заголовок для серий 

Константа ре_стт_скоцрзтіті,е 
Описание: заголовок для групп 
Константа РЕ_етт_ХАХізтітьЕ 
Описание: заголовок оси X 
Константа ре_отт_уахі5тітье 
Описание: заголовок оси V 
Константа ре_отт_2ахізтітье 
Описание: заголовок оси 2 

изеЦебаиІі: ТЙІІЕ, если требуется выводить текстовые элементы гра¬ 

фика, заданные по умолчанию; РА1.3Е, если не требуется 

Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

П РАЬЗЕ — если вызов неудачен. 

Функция РЕЗеызгарЪтехсіпго — позволяет установить требуемую информа¬ 
цию в текстовые заголовки графика. 

СипсСіоп РЕЗеССгарЬТехСІпЕо ( 
ргіпЫоЪ : НогД; 
зесСіогіЦ : Бтаіііпе ; 
дгарЫТ : Етаіііпі. ; 

СіЫеТуре : МогД; 

СіСІе : РСЬаг 
): Вооі зЫсаІІ; 

Параметры функции Описание параметров 

ргіпЫоЬ Номер отчета, в котором требуется установить другие 

заголовки у выбранного графика 

зесбіопы Номер секции, в которой находится график. Этот пара¬ 

метр должен попадать в диапазон значений, возвращае¬ 
мых функцией РЕОеШЗесІіопз 

дгарШ Номер графика, который необходимо настроить в ука¬ 

занной секции. Нумерация графиков начинается с 0 и 
основана на порядке вставки графика в отчет 









Список функций СгузіаІ Иерогі Ргіпі Епдіпе АР I _ 403 



(окончание) 

Параметры функции Описание параметров 



ЫЫеТуре Тип заголовка. Используются константы: 


Константа ре_стт_тітье 

Описание: основной заголовок графика 
Константа ре_стт_5Цвтітье 
Описание: подзаголовок графика 
Константа ре_ѳтт_ роотмоте 
Описание: сноска 
Константа ре_<зтт_зекіезтітье 
Описание: заголовок для серий 
Константа РЕ_етт_скоцрзтітьЕ 
Описание: заголовок для групп 
Константа ре_стт_хахізтітье 
Описание: заголовок оси “X” 

Константа ре_отт_уахі5Тітье 
Описание: заголовок оси “V” 

Константа ре_стт„ 2 АХізтітье 
Описание: заголовок оси “2” 

ЫЫе Строка, содержащая требуемый текст для указанного за¬ 

головка графика 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗееегарЬТуреіпго — позволяет установить тип указанного графика. 

СипсЬіоп РЕЗеСОгарЬТуреІпЕо ( 
ргіпЫоЪ : Мог Д; 
зесСіопИ : Зшаіііпе; 
дгарЬДІ : ЗтаІІіпЬ; 


ѵаг дгарЬТуреІп^о 
): Вооі зЬЗсаІІ; 

: РЕОгарЬТуреІпГо 

Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором необходимо установить тип 
графика 
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Приложение 1 


(окончание) 

Параметры функции Описание параметров 

вессіопм Номер секции, в которой находится график. Этот параметр 

должен попадать в диапазон значений, возвращаемых 
функцией РЕѲеШЗесІіопз 

дгарпм Номер графика, который необходимо настроить в указан¬ 

ной секции. Нумерация графиков начинается с 0 и основа¬ 
на на порядке вставки графика в отчет 

дгарпТуреіпЕо Запись РЕѲгарЬТуреІп^о, которая будет содержать новую 

информацию 

Возвращаемые значения: 

□ ТОЕ — если вызов удачен; 

□ РАЬ5Е — если вызов неудачен. 

Функция РЕЗессгоирсопсііеіоп — позволяет изменить условия группировки. 

Еипсеіоп РЕЗеСОгоирСопЗісіоп ( 
ргіпЫоЪ: ИогЦ; 
зесЫопСоЗе: Зтаіііпе,- 
сопсііСіопРіеІсі: РСЬаг; 
сопсііСІОп: ЗтаІІіпС; 
зогРОігесеіоп; Зтаіііпе 
) : Вооі зЬЗсаІІ; 


Параметры функции Описание параметров 

ргіпсдоЬ Номер отчета, для которого необходимо изменить условия 

группировки 

зестіопСосіе Код секции отчета, для которой необходимо задать усло¬ 

вие группировки 

сопйітіопріеісі Имя поля, значение в котором необходимо изменить. Этот 

параметр можно получить с помощью функции 

РЕОеШапсІІеЗігіпд, преобразовав значения 

сопсШіопРіеІсІНапсІІе и сопсШіопРіеІсНепдЩ, возвращаемые 
РЕО еЮ гои рСопб Шоп 

сопсііт іоп Условие группировки. Используется одна из констант 

РЕ_ОС_ХХХ: 

Константа РЕ_<ЗС_СОНЭІТІОЫМА5К 
Значение — ОхООРР 
Константа РЕ_0С_ТУРЕМА8К 

Значение — ОхОРОО _ 
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(продолжение) 

Параметры функции Описание параметров 

сопсІі'Ь іоп Константа РЕ_ѲС_ТУРЕОТНЕЯ 

Значение — 0x0000 
Константа РЕ_ѲС_ТУРЕОАТЕ 
Значение — 0x0200 
Константа РЕ_ѲС_ТѴРЕВООІ_ЕАЫ 
Значение — 0x0400 
Константа РЕ_ѲС_ТѴРЕТІМЕ 
Значение — 0x0800 

Все типы полей кроме Ѳаіе и Вооіеап 

Константа РЕ_СС_АЫѴСНАЫОЕ 

Описание: отрабатывает группировку каждый раз при на¬ 
личии изменений. 

Поля типа йаіе и ОаіеТіте 

Константа РЕ_ѲС_ОАІІ_У 

Описание: выполняется группировка по каждой дате 
Константа РЕ_ОС_ѴѴЕЕКІ-У 

Описание: выполняется группировка по дате с учетом не¬ 
дели. Все даты, входящие в одну неделю, попадают в одну 
группу. Неделя начинается с воскресенья и завершается 
субботой 

Константа РЕ_ОС_ВІѴѴЕЕКІ_У 

Описание: выполняется группировка по дате за двухне¬ 
дельный период 

Константа РЕ_ѲС_5ЕМІМО№‘НІ_У 

Описание: выполняется группировка по дате за период 
в половину месяца 
Константа РЕ_ОС_МО№ГНІ_У 

Описание: выполняется группировка по дате за период, 
равный месяцу 

Константа РЕ_0С_01ІАЯТЕЯІ_У 

Описание: выполняется группировка по дате за период, 
равный кварталу 

Константа РЕ_СЗС_ЗЕМІАШІІАи_У 

Описание: выполняется группировка по дате за период, 
равный половине года 
Константа РЕ_аС_АШІ)АІ_І_У 

Описание: выполняется группировка по дате за период, 
равный году 
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Приложение 1 
(продолжение) 


Параметры функции Описание параметров 

сопйіъюп Поля типа ОаіеТіте и Тіте РіеШз 

Константа РЕ_ОС_ВУЗЕСОШ 
Описание: группировка по секундам 
Константа РЕ_ѲС_ВУМІШТЕ 
Описание: группировка по минутам 
Константа РЕ_0С_ВУН01ІР 
Описание: группировка по часам 
Константа РЕ_ѲС_ВУАМРМ 
Описание: группировка по времени суток 

Поля типа Вооіеап 

Константа РЕ_<ЗС_ТОУЕЗ 

Описание: выполняется группировка по условию, когда 
значение поля, по которому выполняется сортировка и 
группировка, меняется с N 0 на Уев 

Константа РЕ_ѲС_Т01\Ю 

Описание: выполняется группировка по условию, когда 
значение поля, по которому выполняется сортировка и 
группировка, меняется с Уев на N 0 
Константа РЕ_0С_ЕѴЕЯУУЕ5 

Описание — выполняется группировка в том случае, когда 
значение поля, обеспечивающего сортировку и группиров¬ 
ку, равно Уев 

Константа РЕ_ОС_ЕѴЕЯУШ 

Описание: выполняется группировка в том случае, когда 
значение поля, обеспечивающего сортировку и группиров¬ 
ку, равно N 0 

Константа РЕ_0С_ЫЕХТІЗУЕ5 

Описание: выполняется группировка в том случае, когда 
следующее значение поля, обеспечивающего сортировку и 
группировку, равно Уев 

Константа РЕ_0С_ЫЕХТ13!\Ю 

Описание: выполняется группировка в том случае, когда 
следующее значение поля, обеспечивающего сортировку и 
группировку, равно N 0 

зогтОігесСіоп Условие сортировки для выбранной секции группировки. 

Используются константы: 

Константа РЕ_5Р_ОЕ5СЕШЫО 

Описание: сортировка данных в порядке убывания (от 2 
_к А, от 9 к 1)_ 
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(окончание) 

Параметры функции Описание параметров 

Константы РЕ_ЗР_АЗСЕЫОІШ 

Описание: сортировка данных в порядке возрастания (от А 
к 2, от 1 к 9) 

Константы РЕ_ЗР_ОЯІОІЫАІ_ 

Описание: сортировка данных в том порядке, как они запи¬ 
саны в базу данных 

Константы РЕ_ЗР_ЗРЕСІРІЕО 

Описание: сортировка данных в заданном порядке с до¬ 
полнительными условиями 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


С 


Замечание 




Не существует значений по умолчанию. Все значения для параметров должны 
быть заданы при использовании данной функции. 

Если имеется формула, которая ссылается на поле суммирования, и вы изме¬ 
няете условие на этом поле без фиксации самой формулы, то будет получена 
ошибка. 


Эта функция вызывается всегда перед РЕЗІагіРгіпУоЬог, иначе результат ее 
работы непредсказуем. 


Функция РЕЗеесгоирОрсіопз — позволяет изменить параметры группировки. 

СипсСіоп РЕЗеСОгоирОрСіопз ( 
ргіпЫоЪ: Иогсі; 
дгоирЫ: ЕтаіІіпе ; 
ѵаг дгоирОрЫопз : РЕОгоирОрСіопз 
) : Вооі зрсісаіі; 


Параметры функции 

Описание параметров 

ргіпгДоЬ 

Номер отчета, в котором требуется изменить информа¬ 
цию о параметрах группировки 

дгоирИ 

Номер группы. Нумерация начинается с нуля 

дгоирОрСіопз 

Запись РЕОгоирОрііопз, содержащая параметры группи¬ 
ровки 
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Приложение 1 


Возвращаемые значения: 

□ ткеіе — если вызов удачен; 

□ РАЬ8Е — если вызов неудачен. 


Функция РЕЗеесгоирЗеіесьіопЕ’огшиіа — позволяет изменить формулу, на¬ 
кладывающую ограничения на сгруппированные в отчете данные. Формула 
может быть передана как параметр. Эта функция используется совместно 
с РЕОеЮгоирЗеІесСіопРогтиІа и РЕСеіНапШе8і:гіп§. 

СипсСіоп РЕЗеСОгоирЗеІесСіопЕогтиІа ( 
ргіпСЛоЬ: ИогЦ ; 

СогтиІаЗСгіпд: РСЬаг 
): Вооі зСДсаІІ; 


Параметры функции Описание параметров 

ргіпсЛоЬ Номер отчета, для которого требуется установить новую форму¬ 

лу, ограничивающую сгруппированные значения в отчете 

СогтиІаЗСгіпд Строка, завершающаяся ЫУИ, с текстом формулы 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен в случае возникновения внутренней 
ошибки. 


Функция РЕЗеШагдіпз — позволяет установить параметры границ отчета. 
Используется для установки специфических границ при печати отчета. 

СипсСіоп РЕЗеШагдіпз ( 
ргіпСЛоЪ: ЙогД; 

ІеіС: ИогД; 
гідЬС: ИогД; 

Сор: Иогй; 

ЬоССот: ИогД 
): Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпСЛоЪ 

Номер отчета, для которого необходимо изменить пара¬ 
метры границ 

ІеСС 

Ширина левой границы 

гідЬС 

Ширина правой границы 
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(окончание) 

Параметры функции 

Описание параметров 


сор 

Ширина верхней границы 


ЬоТ'Ьот 

Ширина нижней границы 



Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеешеСаіісоріез — позволяет распечатать множество копий 
детальной секции отчета. Для определения количества экземпляров деталь¬ 
ной секции используется функция РЕОеіЫВеіаіІСоріез. 

СипсСіоп РЕЗеШОеСаіІСоріез ( 
ргіпЫоЪ: МогЦ; 
ѵаг пОеЬаіІСоріез: Іпеѳдег 
): Вооі зЫсаІІ; 


Параметры функции Описание параметров 

ргіпЬДоЬ Номер отчета, в который передается информация о коли¬ 

честве распечатываемых секций Оеіаіі 

пЦеСаііСоріез Количество распечатываемых копий секции Оеіаіі 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗешеЬАіегссопаісіопГогтиіа — позволяет задать условие для 
определенного предупреждения в отчете (Керогі АІеП). 

іипсСіоп РЕЗеШСЬАІегССопсііСіопРогшиІа ( 
ргіпСДоЬ : Йога,- 
аіегсы : ЗтаІІіпС,- 
сопзС Еогтиіа : РСЬаг 
) •. Вооі зСдсаІІ; 


Параметры функции 

Описание параметров 

ргіпрДоЬ 

Номер отчета, для которого необходимо задать условие на 
обработку предупреждения 
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(окончание) 

Параметры функции 

Описание параметров 


аіегш 

Номер предупреждения, для которого задается условие 

Еогтиіа 

Строка, содержащая текст условия, 
вается предупреждение 

по которому обрабаты- 


Возвращаемые значения: 

□ ТВІШ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


ФуНКЦИЯ РЕЗеСШЩАІегиЭегаиІШеззаде — ПОЗВОЛЯет Определить Текст СО- 
общения по умолчанию для выбранного предупреждения в отчете. 

ЕипсСіоп РЕЗеЫЩЪАІегиЭеЕаиІЬМеззаде ( 
ргіпСДоЬ : Иогсі; 
аІегСЫ : БтаІІіпС; 
сопзе СехС : РСЬаг 
) : Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпС ДоЬ 

Номер отчета, для которого требуется определить текст 
сообщения по умолчанию 

аІегСЫ 

Номер предупреждения, для которого требуется опреде¬ 
лить текст сообщения по умолчанию 

Сехе 

Строка, содержащая текст сообщения по умолчанию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


ФуНКЦИЯ РЕЗеЪЫСЪАІегШеззадеГогтиІа — ПОЗВОЛЯет Определить текст СО- 
общения для предупреждения, связанного с отчетом. 

СипсСіоп РЕЗеШСЬАІегСМеззадеРогтиІа ( 
ргіпЫоЪ : Иог<3; 
аІегШ : ЗтаІІіпС; 
сопзС Согтиіа : РСЬаг 
) : Вооі зСйсаІІ; 
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Параметры функции 

Описание параметров 

ргіпЬДоЬ 

Номер отчета, для которого требуется определить текст 
сообщения 

аІегШ 

Номер предупреждения, связанного с отчетом 

Гогтиіа 

Строка, содержащая текст сообщения 


Возвращаемые значения: 

□ ТЯЕІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеыіььегоирЗогьгіеісі — позволяет установить параметры для 
одного из полей, по которому в отчете выполняется сортировка и группи¬ 
ровка. Эта функция используется только для модификации уже существую¬ 
щего условия. Новое условие не может быть создано с ее помощью. 

СипсЬіоп РЕЗеЬЫОіСгоирЗогЬРіеІсі ( 
ргіпЫоЪ: Иогсі; 
зогЬРіеІйЦ: ВтаІІіпЬ ; 
пате : РСЬаг; 
сіігесьіоп: ЗтаІІіп'Ь 
): Вооі зЬйсаІІ; 


Параметры функции 

Описание параметров 

ргіпЬЛоЬ 

Номер отчета, в котором необходимо изменить параметры 
поля, обеспечивающего группировку и сортировку данных 

зогЬРіеІсШ 

Номер поля, которое необходимо перенастроить. Нумера¬ 
ция полей начинается с 0 

паше 

Строка, содержащая наименование поля, обеспечивающе¬ 
го группировку и сортировку в отчете 

сіігесьіоп 

Порядок сортировки. Используются следующие константы: 
Константа РЕ_ЗР_СЕ5СЕШ|ЫО 

Описание: сортировка данных в порядке убывания (от 2 до 

А, от 9 до 1) 

Константа РЕ_ЗР_АЗСЕШІНО 

Описание: сортировка данных в порядке возрастания (от А 
до 2, от 1 до 9) 

Константа РЕ_ЗР_ОЯІОІНАІ_ 

Описание: только для полей группировки — сортировка 
данных в оригинальном порядке 

Константа РЕ_5Р_5РЕСІРІЕО 

Описание: только для полей группировки — сортировка 


данных в специальном порядке. Только для чтения 


14 Зак. 1021 
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Возвращаемые значения: 

П ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕзестщрагатеііегПегаиііѴаіие — позволяет установить значение по 
умолчанию в поле-параметр. Для уточнения информации о количестве значе¬ 
ний по умолчанию используется функция РЕОеШРагатеІегОеГаиІіѴаІиез. 

іипсСіоп РЕЗеШЙіРагатеСегЦеіаиІСѴаІие ( 
ргіпЫоЪ: Иогд; 

сопзс рагатеЬегРіеІсЗЦате: РСЬаг; 
сопзс герогШате: РСЬаг; 
іпсіех: БтаІІіпС; 
ѵаг ѵаіиеіпіо: РЕѴаІиѳІп^о 
) : Вооі зМсаІІ; 


Параметры функции 

Описание параметров 

ргіпЫоЬ 

Номер отчета, в котором требуется установить значение 
по умолчанию для поля параметра 

рагатеСегЕіеІсіЫате 

Строка, содержащая имя поля, которое является пара¬ 
метром отчета 

герогШате 

Строка, содержащая имя отчета 

іпсіех 

Индекс значения по умолчанию, которое необходимо пе¬ 
реопределить 

ѵаіиеіпіо 

Запись РЕѴаІыеІпЬ, которая будет содержать значение по 
умолчанию 


Возвращаемые значения: 

□ ТГШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ^ 

Ожидаемые значения для параметра герогШате: 

• для основного отчета можно определить пустую строку 

• для подотчета необходимо указать путь к файлу и имя подотчета как 
завершенную строку. 
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Функция РЕЗеЪыььРагаіпвЪегГіеіЦ — позволяет установить значение в ука¬ 
занное поле параметр отчета. 

Сипсеіоп РЕЗеШйіРагатеСегРіеІсІ ( 
ргіпЫоЬ: Йога,- 
ѵагИ: БтаІІіпЪ; 

ѵаг ѵагІпЕо: РЕРагалѵѳЬегЕіеіаіпЕо 

) : Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, который содержит поле параметр, в кото¬ 
ром необходимо изменить значение 

рагатеСегИ 

Номер параметра, который требуется изменить 

рагатеСегІпСо 

Запись РЕРагатеіегРіеІсІІпіо, которая используется для 
передачи требуемой информации 

Возвращаемые значения: 

□ ТГШЕ — если вызов удачен; 

П РАЬЗЕ — если вызов неудачен. 

Функция РЕЗе^ЬЬРагатеЬегѴаІиеПезсгірЬіоп — ПОЗВОЛЯет уСТЭНОВИТЬ 

описание для поля параметра. 

ЕипсЬіоп РЕЗеС№ЦРагатееегѴа1иеЦезсгір(:іоп ( 

ргіпРДоЬ : Иогсі ; 
рагате ЬегРіе1(ЗМате 
герогЬНате : РСЬаг; 
іпсіех : ЗтаІІіігЬ; 
ѵаІиеЦезс : РСЬаг 

-. РСЬаг; 

) : Вооі зЫсаІІ; 


Параметры функции 

Описание параметров 

ргіпедоь 

Номер отчета, в котором требуется установить описание 
для поля параметра 

рагатеСегРіеІсШате 

Строка, содержащая имя поля параметра 

герогШате 

Строка, содержащая имя отчета 

іпсіех 

Индекс параметра 

ѵаІиеОезс 

Строка, содержащая текст, который будет использован 
в качестве описания для поля параметра 
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Приложение 1 


Возвращаемые значения: 
п тіше — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ) 

Ожидаемые значения для параметра герогШате: 

• для основного отчета можно определить пустую строку 

• для подотчета необходимо указать путь к файлу и имя подотчета как ЫІІИ- 
завершенную строку. 


Функция РЕ5ешеьзог№іеіа — позволяет указать поле отчета, по которому 
будет выполняться сортировка данных. 

ЕипсСіоп РЕЗеЫДЛіЗогСРіеІсІ ( 
ргіпСДоЬ: ИогД; 
зогСРіеІдЦ: 8та11іігЬ; 
пате: РСЬаг; 
ѵаг Йігесьіоп: Иог<і 
): Вооі зьдсаіі; 


Параметры функции Описание параметров 


ргіпСДоЬ 


зогСРіеІсШ 


пате 

ОігесСіоп 


Номер отчета, в котором требуется установить специфи¬ 
ческие параметры сортировки 

Номер поля, которое будет использовано при сортировке. 
Нумерация полей начинается с О 

Строка, содержащая имя поля 

Константа, определяющая направление сортировки: 

Константа ре_8Р_резсеж>шс 

Описание: сортировка данных в порядке убывания (от 2. 
до А, от 9 до 1) 

Константа ре_зр_азсеж>шс 

Описание: сортировка данных в порядке возрастания (от 
А до 2, от 1 до 9) 

Константа ре_зр_окісшаь 

Описание: только для полей группировки — сортировка 
данных в оригинальном порядке 
Константа ре_зр_зресіріее 

Описание: только для полей группировки — сортировка 
данных в специальном порядке. Только для чтения 
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Возвращаемые значения: 

□ тіше — если вызов удачен; 

□ РАЬ8Е — если вызов неудачен. 


Функция РЕЗеымщтаЫеъосаііоп — позволяет изменить местоположение 
указанной таблицы в выбранном отчете. Эта функция используется совме¬ 
стно с РЕОеШШТаЫеЬосабоп. 

ЕипсСіоп РЕЗеСЫЫіТаЫеЬосаеіоп ( 
ргІпСДоЬ: Иогд; 

СаЫеЫ: іггЬедег ; 

ѵаг ІосаСіоп: РЕТаЫеІюоаііоп 

) : Вооі зСсІсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором необходимо изменить местопо¬ 
ложение таблиц, используемых для формирования набо- 


ра данных для отчета 

СаЫеЦ 

Номер таблицы, используемой при формировании отчета. 
Нумерация таблиц начинается с 0 

ІосаСіоп 

Запись РЕТаЫеІ_осаІіоп, содержащая данные о таблице. 
Формат строки зависит от типа источника, используемого 
для формирования отчета 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеШЪЬТаЫеЬодошпго — позволяет изменить параметры под¬ 
ключения к источнику данных для выбранной в отчете таблицы. 

іипсЬіоп РЕЗеЬЫСЬТаЫеЬодОпІпЕо ( 
ргіпЫоЬ: Могд ; 

СаМеЫ: Зпѵаі ІіггЬ; 
ѵаг ІодОпІпЕо: РЕЬодОпХпСо ; 
ргорадаСеАсгоззТаЫез: Вооі 
) : Вооі зЫсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором необходимо изменить информа¬ 
цию о том, как подключаться к таблице в источнике данных 
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Приложение 1 


(окончание) 


Параметры функции Описание параметров 

ЬаЫеН Номер таблицы, используемой для построения отчета. 

Нумерация таблиц начинается с О 

ІодОпіпЕо Запись РЕІ_одОпІп{о, содержащая всю необходимую 

для подключения к базе данных информацию 

ргорадаСеАсгоззТаЫез Если ТНІІЕ — программа выполнит подключение к 

базе данных с указанными параметрами для всех 
таблиц, которые присутствуют в отчете. Если РАІ-8Е — 
то указанные параметры будут применены только к 
выбранной таблице 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

( Замечание ^ 

Для получения дополнительной информации смотрите описание функции 
РЕІ_одОпЗегѵег. 


Функция РЕЗешеьтаЫеРгіѵаееіпДо — позволяет передать в отчет инфор¬ 
мацию, необходимую при использовании таких объектов данных, как АОО, 
ОАО, ІШО или СОО с соответствующими драйверами Асііѵе Оаіа Огіѵегх 
(сг<ЗЬ_ас1о.<Ш, сгс1Ъ_с1ао.сШ, с гсіЬ_осіЬс . сі 11, сгбЬ_ссіо.сШ). 

СипсСіоп РЕЗеШСЬТаЫеРгіѵаСеІпЕо ( 
ргіпЫоЪ: Иогсі; 

СаЬІеЫ: Етаі1іпЬ; 

ѵаг ргіѵаГеІпЕо: РЕТаЫѳРгіѵа'ЬеІпЕо 
) :Воо1 зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, который использует таблицы, требующие 
информацию о сессии связи с источником 

ЬаЫеИ 

Номер таблицы, для которой необходимо передать ин¬ 
формацию. Нумерация таблиц начинается с 0 

ргіѵаСеІпСо 

Запись РЕТаЫеРгіѵаІеІпіо, содержащая необходимую 
информацию 
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Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеШЫгТаЫеЗѳззіопіпго — позволяет передать информацию, 
необходимую для организации сессии с таблицами Місгохой Ассезз, исполь¬ 
зуемыми в отчете. Данная функция передает следующую информацию: Ііхег 
Ю, Ра55\ѵогб и Зеззіоп Напбіе. 

іипсСіоп РЕЗеСЫОіТаЪІеЗеззіопІпбо ( 
ргіпЫоЪ: Иог<3; 

СаЫеЫ: БшаІІіпЬ; 
ѵаг зезз іопіпЕо : РЕЗеззіопІпіо; 
ргорадаСеАсгоззТаЫез: Вооі 
); Вооі зЫсаІІ; 


Параметры функции 

Описание параметров 

ргіпС ДоЬ 

Номер отчета, требующий передачи информации 
о сессии 

СаЫеЫ 

Номер таблицы, используемой в отчете. Нумерация 
таблиц начинается с 0 

зеззіопІпЕо 

Запись РЕЗеззіопІпіо, которая содержит требуемую 
информацию 

ргорадаСеАсгоззТаЫез 

Если ТЯІІЕ— программа выполнит подключение 
к базе данных с указанными параметрами для всех 
таблиц, которые присутствуют в отчете. Если РАІ_ЗЕ — 
то указанные параметры будут применены только 
к выбранной таблице 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


С 


Замечание 



Эта функция может быть использована только для баз данных М3 Ассезз, ко¬ 
торые требуют открытия сессии, прежде чем будет обеспечен доступ к базе. 
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Приложение 1 


Функция РЕЗеЬРагатеЪегміпмахѴаіие — позволяет передать минимальное и 
максимальное значение в указанное поле параметр в отчете. 

іипсьіоп РЕЗеЬРагатеЬегМіпМахѴаІие ( 
ргіпЬЛоЬ: Мог Д; 

сопзс рагаліеСегРіеІйЦате : РСЬаг; 
сопзС герогШате: РСЦаг; 
ѵаг ѵаІиеМіп: РЕѴаІиеІпТо; 
ѵаг ѵаІиеМах: РЕѴаІиеІпТо 
): Вооі зсДсаІІ; 


Параметры функции 

Описание параметров 

ргіпШоЬ 

Номер отчета, в который необходимо передать минималь¬ 
ное и максимальное значение параметра 

рагатеСегРіеІДЫате 

Строка, содержащая имя поля параметра 

герогШате 

Строка, содержащая имя отчета 

ѵаІиеМіп 

Запись РЕѴаІиеІпІо, в которую возвращается информация 
о минимальном значении параметра 

ѵаІиеМах 

Запись РЕѴаІиеІпЬ, в которую возвращается информация 
о максимальном значении параметра 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ) 

Предполагаемое значение параметра герогШате: 

• для основного отчета пустая строка 

• для подотчета пути и имени подотчета как строка, завершающаяся N1)11. 
Предполагаемые значения для параметров ѵаІиеМіп и ѵаІиеМах: 

• установите ѵаІиеМіп в N1)1.1- для передачи только максимального значения и 
установите значение, отличное от N1)1.1-, если ѵаІиеМах равно N1)1.1-; 

• установите ѵаІиеМах в N1)1.1- для передачи только минимального значения и 
установите значение, отличное от -N111.1-, если ѵаІиеМіп равно ПІ)І_І_. 

Функция РЕ5еіРагатеЪегРіскЬізЪОр Ъхоп — ПОЗВОЛЯет передать СПИСОК НД- 
строек для параметра в указанном отчете. 

ЬлпсСіоп РЕЗеСРагатеСегРіскЬізСОрСіоп ( 
ргіпЫЪЪ : Мог Д ; 
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рагатеСегРіеІйМате 
герогСЫате : РСЪаг 
ѵаг ріскЬізсОрСіоп 
): Вооі зСДсаІІ; 

: РСЪаг; 

: РЕРагатеьегРіскЪізьОрьіоп 

Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в который необходимо передать список 
настроек для параметра 

рагатеСегГіеІсЩате 

Строка, содержащая имя параметра 

герогШате 

Строка, содержащая имя отчета 

ріскЬізСОрСіоп 

Запись РЕРагатеіегРіскІ_І5Юрііоп, которая будет содер¬ 
жать передаваемую информацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 

Г Замечание ) 

Ожидаемое значение параметра герогШате: 

• для основного отчета пустая строка 

• для подотчета пути и имени подотчета как строка, завершающаяся МІ)І_І_. 

Функция РЕЗеСРагатеСегѵаіиеіпго — позволяет передать информацию 
о значениях, которые могут быть записаны в поле параметр. 

ЕипсСіоп РЕЗеЬРагатеСегѴаІиеІпЕо ( 
ргіпЫоЬ : Иогсі; 

сопзс рагатеЬегРіеІдЦате : РСНаг,- 
сопзЬ герогСЫат : РСПаг; 
ѵаг ѵаІиеІпЕо : РЕРагаіпе'ЬѳгѴаІиѳІпГо 
) : Вооі зСсІсаІІ; 


Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в который необходимо передать информа¬ 
цию о параметре 

рагатеСегІГіеІсДОате 

Строка, содержащая имя поля параметра 

герогЬИате 

Строка, содержащая имя отчета 

ѵаіиеІпТо 

Запись РЕРагаплеІегѴаІиеІпІо, в которой содержатся тре¬ 
буемые данные 
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Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЫ8Е — если вызов неудачен. 

( Замечание ^ 

Ожидаемое значение параметра герогІЫате: 

• для основного отчета пустая строка 

• для подотчета пути и имени подотчета как строка, завершающаяся ЫІІИ. 


Функция РЕЗеСРгхпиэаЪе — позволяет изменить дату печати, которая опре¬ 
делена в отчете. 

іипсСіоп РЕЗСеСРгіпЫЭаСе ( 
ргіпЫЪЪ: ИогЙ; 
ѵаг уеаг: Иогд; 
ѵаг топЙі: ИогЦ; 
ѵаг <3ау: Иог<а 
): Вооі зСДсаІІ; 


Параметры функции 

ргіпСДоЬ 

уеаг 

шопСЬ 

йау 


Описание параметров 

Номер отчета, в котором требуется изменить дату печати 
Номер, соответствующий четырем цифрам года 
Номер, соответствующий двум цифрам месяца 
Номер, соответствующий двум цифрам числа 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


( Замечание ) 

Изменение значения даты печати может потребоваться в случае, когда вы пе¬ 
чатаете отчет сегодня, а дата печати должна стоять другая. 


Функция РЕЗеЪРгіпѣОрЪіопз — позволяет установить параметры для печати 
отчета. 

ЕипсСіоп РЕЗеСРгіпСОрСіопз ( 
ргіпЫоЪ: Ногд; 
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ѵаг орсіопз: РЕРгіпЬОрЬіопе 
) : Вооі зСсІсаІІ; 


Параметры функции 

Описание параметров 

ргіпС ДоЬ 

Номер отчета, в котором требуется изменение текущих 
параметров печати 

орііопз 

Запись РЕРгіпЮрИопз, которая содержит требуемые па- 
раметры. Если этот параметр установить равным 0 
(ШИ), функция предоставит возможность пользователю 
задать требуемые параметры в диалоге настройки печати 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗескерогеорСіопа — позволяет установить изменяемые пара¬ 
метры отчета, передаваемые с помощью записи РЕВерогіАІегіІпГо. 

ЁипсЬіоп РЕЗеЬКерогТОрсіопз ( 


ргіпЫоЬ: Иогй,- 
ѵаг герогСОрСіопз : 
): Вооі зСдсаІІ; 

РЕНерогСОрСіопв 

Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета, в котором требуется изменить основные 
настройки 

герогСОрСіопз 

Запись РЕЯерогІАІеіІІпІо, содержащая требуемую ин¬ 
формацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеЬКероГ'ЬЗилшіагуІп^о — ПОЗВОЛЯеТ ИЗМеНИТЬ Суммарную ин¬ 
формацию об отчете, которая была определена через диалог Зшпшагу Іпіо, 
находящийся в Сгузіаі КероПз. 

іипсСіоп РЕЗеСКерогСЗиіптагуІпСо ( 
ргіпЫоЪ: МогД; 
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ѵаг зшпшагуІпСо: 

): Вооі зеДсаІІ; 

РЕКерогеЗигпшагуіпТ о 

Параметры функции 

Описание параметров 

ргіпСДоЬ 

Номер отчета , в котором требуется изменить информацию 

зштапагуіпі'о 

Запись РЕЯерогіЗиплтагуІпіо, содержащая необходимую 
информацию 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеСКерог'ЬТіеіе — используется для изменения заголовка отчета 
в разделе суммарной информации. 

Сипссіоп РЕЗеСКерогстіСІе ( 
ргіпЫоЪ: Иогй; 

СіСІе: РСЬаг 
): Вооі ЗГЛсаІІ; 


Параметры функции Описание параметров 

ргіпе ДоЬ Номер отчета, в котором требуется изменить заголовок 

ьіЫе Строка, которая будет использована в качестве заголовка 

отчета 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеСЗесЫопГогтаД — позволяет изменить параметры форматиро¬ 
вания выбранной секции в отчете, которые передаются с помощью записи 
РЕЗесІіопОрІіопз. 

ЕипсЫоп РЕЗеЬЗесЫопРогтаС ( 
ргіпЫоЪ: Ногд ; 
зесЫопСоЦе: ЕшаІІіпЪ ; 
ѵаг орсіопз : РЕЗесСіопОр'Ьіопз 
): Вооі зЬйсаІІ; 
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Параметры функции 

Описание параметров 

ргіпС ОЪЬ 

Номер отчета, в котором необходимо изменить парамет¬ 
ры форматирования указанной секции 

зессіопСойе 

Код секции, для которой требуется изменить параметры 
форматирования. Код секции можно получить с помощью 
функции РЕѲеІЗесІіопСогіе 

орсіопз 

Запись РЕЗесііопОрііопз, которая будет содержать тре¬ 
буемую информацию 


Возвращаемые значения: 

□ ТШЛЕ — если вызов удачен; 

□ РАЬ8Е — если вызов неудачен. 


Функция РЕЗеЪЗесЪіопРогтаеРопшіа — позволяет изменить формулу, с по¬ 
мощью которой выполняется форматирование указанной секции. Эта функ¬ 
ция позволяет изменить только формулу, которая уже существует в отчете. 

Еипссіоп РЕЗеЬЗессіопРогтпаСРогтпиІа ( 
ргіпЫоЪ: ИОГЙ; 
зесСіопСойе: ЗтаІІіхгЬ; 
і. огтиі аЦате : Зтаі 1 іпЬ ; 

ЕогтиІаЗСгіпд: РСЬаг 
): Вооі зсдсаіі; 


Параметры функции Описание параметров 


ргіпСДоЬ 


зессіопСойе 


іогтиІаЫате 


Номер отчета, для которого требуется изменить текст 
формулы, по которой форматируется секция 

Код секции, который может быть получен с помощью 
функции РЕѲеІЗесІіопСосіе 

Имя формулы, обеспечивающей форматирование. Ис¬ 
пользуются константы: 

Константа РЕ_РР^АЯЕА5ЕСТЮГ\І_ѴІ5ІВіиТѴ 
Описание: формула форматирования области отчета и 
отдельной секции 

Константа РЕ_РРМ_5ЕСТЮІ\І_ѴІ5ІВіиТѴ 

Описание: формула форматирования секции 

Константа РЕ_РРН_5НОѴѴ_АЯЕА 

Описание: формула форматирования области отчета 

Константа РЕ_РРИ_ЫЕѴѴ_РАОЕ_ВЕРОЯЕ 

Описание, формула форматирования области отчета и 

отдельной секции 
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(окончание) 

Параметры функции Описание параметров 



іогтиІаЫаше Константа РЕ_РР(\І_ЫЕѴѴ_РАѲЕ_АРТЕЯ 


Описание: формула форматирования области отчета и 
отдельной секции 

Константа РЕ_РРЫ_КЕЕР_ТОѲЕТНЕВ 

Описание: формула форматирования области отчета и 

отдельной секции 

Константа РЕ_РР[\І_ЗІІРРЯЕ38_ВІ_АМК_5ЕСТЮМ 
Описание: формула форматирования секции 
Константа РЕ_РРГ\І_ЯЕЗЕТ_РАѲЕ_М_АРТЕЯ 
Описание: формула форматирования области отчета и 
отдельной секции 

Константа РЕ_РРЫ_РЯІЫТ_АТ_ВОТТОМ_ОР_РАОЕ 
Описание: формула форматирования области отчета и 
отдельной секции 

Константа РЕ_РРМ_ІІШЕЙІ_АѴ_ЗЕСТЮЫ 
Описание: формула форматирования секции 
Константа РЕ_РРМ_ЗЕСТЮЫ_ВАСК_С0І_011Я 
Описание: формула форматирования секции 
Константа РЕ_РРЫ_5ЕСТЮМ_ВАСК_СОІ_ОЯ 
Описание: формула форматирования секции 

іогтиіазсгіпд Строка, содержащая новый текст формулы форматирова¬ 

ния секции 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен; 

□ код ошибки РЕ_ЕКІІ_ВАОРОК.МІЛА^АМЕ — если формула не сущест¬ 
вует; 

□ код ошибки РЕ_ЕКК._ВАВРОКМЕІЕАТЕХТ — если в тексте формулы 
есть ошибка. 


Функция РЕЗеЪЗесЪіопНеідЫ; — изменяет высоту заданной секции в отчете. 

ЕипсЬіоп РЕЗеСЗесЬіопНеідЫ: ( 
ргіпЫоЪ: НогЦ ; 
зесСіопСоДе: Зтаіііпе; 

НеідЫ:: ЗтаІІіпЪ 
): Вооі зьасаіі; 
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Параметры функции 

Описание параметров 

ргіпе ДоЬ 

Номер отчета, в котором изменяется информация о высо¬ 
те секции 

зесСіопСосіе 

Код секции, который может быть получен с помощью 
функции РЕСеіЗесііопСосІе 

ЬеідЬС 

Высота секции 


Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеСЗеІесеіопЕ’огтиІа — ИСПОЛЬЗуеТСЯ ДЛЯ Изменения формулы, 
ограничивающей выборку данных в отчет из источника. Эта функция может 
быть использована как сама по себе, так и в составе с функциями 
РЕОегёеІесііопРоппиІа, РЕСеШапсИеЗЫщ?. 

ГипсСіоп РЕЗеСЗеІесСіопРогтиІа ( 
ргіпСДоЬ: Иогй; 

ГогтиІаЗСгіпд: РСЬаг 
) : Вооі зЬЗсаІІ; 


Параметры функции 

ргіпСДоЬ 


ГогтиІаЗСгіпд 


Описание параметров 

Номер отчета, в котором требуется изменить формулу, 
ограничивающую выборку данных 

Строка, содержащая текст новой формулы 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — в случае возникновения внутренней ошибки. 


Функция РЕЗеезсідЕхргевзіоп — позволяет изменить БС^Ь-выражение в ука¬ 
занном отчете. 

ГипсЬіоп РЕЗеЬЗ<2і,Ехргеззіоп ( 
ргіпЫоЪ: ИогЙ; 
сопзЬ ехргезз іопі-іаігіе : РСЬаг; 
сопзС ехргезз іопзыіпд: РСЬаг 
) ; Вооі зСсісаІІ; 
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Параметры функции Описание параметров 

ргіпсЛоЬ Номер отчета, в котором необходимо заменить 301- 

выражение 

ехргеззіопЫате Строка, содержащая имя выражения 

ехргеззіопЗсгіпд Строка, содержащая новый текст 30 1_- выражения 

Возвращаемые значения: 

□ ТКІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗесзоьоиегу — используется для изменения $0Е-запроса в от¬ 
чете. Обычно используется для изменения части ЗС^Ь-запроса, относящейся 
к предложению ѴѴНЕК.Е. 

ГипсСіоп РЕЗеСЗдьдиегу ( 
ргіпСДоЬ: Ног<3 ; 
диегуЗСгіпд : РСЬаг 


): Вооі зЫсаІІ; 

Параметры функции 

Описание параметров 

ргіпЫоЬ 

диегуЗСгіпд 

Номер отчета, в котором требуется отредактировать 30І_-запрос 

Строка, содержащая измененный ЗСД-запрос 


Возвращаемые значения: 

□ ТІШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеСТгаскСигзогтго — позволяет установить параметры курсо¬ 
ра, отображаемого в определенной области окна просмотра отчета. Эта 
функция может быть использована только при просмотре отчета. 

ГипсСіоп РЕЗеСТгаскСигзогІпбо ( 
ргіпЬДоЬ: ЗтаІІігЛ; 
ѵаг сигзогІпГо: РЕТгаскСигзогІпГо 
) : Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпСОЪЬ 

Номер отчета, в котором требуется управлять типом курсора 

сигзогІпГо 

Запись РЕТгаскСигзогІпІо, которая будет содержать, ин¬ 
формацию о типе курсора 
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Возвращаемые значения: 

□ ТКНЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция РЕЗеШіпаоиОрііопз — позволяет установить параметры окна про¬ 
смотра отчета, включая доступные элементы контроля. Эта функция должна 
вызываться после РЕОЩрщТоѴѴінсіоѵ/. 

іипсСіоп РЕЗеШіпДоадОрСіопз ( 
ргіпЫЪЪ: Нога ; 
ѵаг орСіопз: РЕИіпдоѵЮрСіопз 
) :Воо1 зьсісаіі; 


Параметры функции Описание параметров 

ргіпсдоЬ Номер отчета, который должен быть открыт в настраивае¬ 

мом окне просмотра 

РЕИіпсіоыОрсіопз Запись РЕѴѴІпсІоѵѵОрііопз, в которой будет содержаться 

информация о параметрах окна просмотра 


Возвращаемые значения: 

□ ТК.ЕІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функции РЕЗЬоѵЕігзЬРаде, РЕЗЬоѵДазЬРаде, РЕЗЪоиЫех-ЬРаде, 

РЕЗЬоѵРгеѵіоизРаде, РЕЗЬоѵЛШіРаде — ИСПОЛЬЗуЮТСЯ ДЛЯ ВЫВОДД указанной 

страницы в окно просмотра. Для определения количества страниц в отчете 

используйте функцию РЕОеЕЧРа§е5. 

1. Показать первую страницу отчета. 

ТипсСіоп РЕЗЬотоРігзСРаде ( 
ргіпЫЪЪ : Иогй 
): Вооі зСйсаІІ; 

2. Показать последнюю страницу отчета. 

ТипсСіоп РЕЗЬотоЬазСРаде ( 
ргіпЫЪЬ: Иогй 
): Вооі зсДсаІІ; 

3. Показать следующую страницу отчета. 

ЕипсСіоп РЕЗЬоШехСРаде ( 
ргіпСДоЬ: Йога 
): Вооі зЫсаІІ; 


I 5 Зак. 1021 
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4. Показать предыдущую страницу отчета. 

Силсе іоп РЕЗДоадРгеѵіоизРаде ( 
ргіпЫоЪ: Иогй 
): Вооі зесісаіі; 

5. Показать выбранную страницу отчета. 

Силсе іоп РЕЗДоадЫЙіРаде ( 
ргіпеДоЬ: Могй; 
радеЫ: Зтаіііпе 
) : Вооі зесісаіі ; 


Параметры функции 

Описание параметров 

ргіпедоь 

Номер отчета, для которого необходимо выбирать стра¬ 
ницы 

Данный параметр появляется только в функции 
РЕЗЬоѵ/ЫіЬРаде 

радеЫ 

Номер страницы, которую требуется вывести в окно про¬ 
смотра. Нумерация страниц начинается с 1 


Возвращаемые значения: 

□ ТК.ІІЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция резьомРг іпесопЬгоі б — позволяет выводить в окно просмотра от¬ 
чета кнопки навигации — кнопки Рігяі, Ргеѵіоик, N6x1 и Ьазі Ра^е и также 
кнопки Сапсеі, Сіоке, Ехрогі и Ргіпі Іо Ргіпіег. 

Силсеіоп РЕЗЪоѵгРгіпеСопегоІз ( 
ргІпеДоЬ: ИогЦ; 
зЬомРгілеСопегоІз: Вооі 
): Вооі зесісаіі; 


Параметры функции 

Описание параметров 

ргіпедоь 

зЬоиРгіпеСопегоІз 

Номер отчета, который будет выведен в окно просмотра 

ТВІІЕ — если кнопки должны быть показаны, РАІ-ЗЕ — 
если кнопки не нужны 


Возвращаемые значения: 

□ ТКИЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 
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Функция РЕЗСагСРгіпсдоЬ — выполняет печать отчета в окно просмотра, на 
принтер и т. п. 

іипсріоп РЕЗСагСРгіпЫоЪ ( 
ргІпЫОЬ: Когй; 
юаіСШРіЮопе: Вооі 
): Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпТЛоЬ 

маіТІІпТіІОопе 

Номер отчета, который должен быть обработан 

Этот параметр всегда должен быть ТПІІЕ. Он зарезерви¬ 
рован для следующих версий 


Возвращаемые значения: 

□ ТК.ІІЕ — если вызов удачен; 

□ РАЬВЕ — если вызов неудачен. 


Функция РЕТезшеьтаЫеСоппесеіѵіеу — позволяет выполнить проверку 
параметров подключения к базе данных. 

іипсСіоп РЕТезШСПтаЪІеСоппесСіѵіСу ( 
ргіпЫоЪ: Иогд; 

ЬаЫ еМ: ЗтаіІіпр 
): Вооі зЬЗсаІІ; 


Параметры функции 

Описание параметров 

ргіпТЛоЬ 

Номер отчета, для которого требуется проверить коррект¬ 
ность параметров подключения к источнику данных 

РаЫеЫ 

Номер таблицы, для которой требуется проверить пара¬ 
метры подключения. Нумерация таблиц в отчете начина¬ 
ется с 0 


Возвращаемые значения: 

□ ТК.ЕІЕ — если вызов удачен; 

□ РАЕЗЕ — если вызов неудачен. 
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( Замечание 


Если параметры 
ошибки: 

подключения неверны, то 

можно отследить следующие 

Ошибка 

соединения 

Код ошибки 

Исправляется с помощью 
функции 

Невозможно 
начать сессию 

РЕ_ЕНК_ПАТАВА5ЕЗЕ55І0Ы 

РЕЗе'ШШГаЫеЗеззіопІпіо 

Невозможно 
подключиться 
к серверу 

РЕ_ЕКК_БАТАВА5 ЕЬОСОЫ 

РЕЗеРЫРЬТаЫеЬодОпІп^о 

Невозможно 
открыть таблицу 

РЕ_ЕЕК_ВАТАВАЗЕЬОСАТІОЫ 

РЕЗе'ЬЦрЬТаЫеЬосаРіоп 

Функция РЕѴегіДуЦаеаЬазе — позволяет выполнить проверку структуры 
подключенной базы данных на соответствие структуре базы, определенной 
в отчете. 

іипсьіоп РЕѴегііуБаСаЬаБе 
ргіпЫоЪ: Йога 
) : Вооі зРЗсаІІ; 


Параметры функции 

Описание параметров 


ргіпРДоЪ 

Номер отчета, для которого требуется выполнить про¬ 
верку 


Возвращаемые значения: 

□ ТГШЕ — если вызов удачен; 

□ РАЬЗЕ — если вызов неудачен. 


Функция ре 2 оотР геѵіеѵдоіпсіоѵ — позволяет управлять размерами просмат¬ 
риваемого отчета в определенных рамках: Риіі Ра§е, Ріі Опе 8ісіе, Ріі ВоіЬ 
Зісіез или другой вариант. 

іипсЪіоп РЕ2оотРгеѵіеадИіпсіом ( 
ргіпЬЛоЬ: Иогй ; 

Іеѵеі: ЗтаІІіпС 
): Вооі зрйсаіі; 
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Параметры функции Описание параметров 

ргіпРЛоЪ Номер отчета, который необходимо изменять в пределах 

окна просмотра 

Іеѵеі Варианты размеров, которые вы можете установить, 

должны попадать в пределы от 25% до 400%. Так же 
можно использовать некоторые константы: 

РЕ_ 2 ООМ_РІІЬ Ь_ 312 Е 

РЕ_200М_3І2Е_РІТ_ОЫЕ_3 ІБЕ 

РЕ_200М_512 Е_РІТ_ВОТН_5ЮЕ5 

Возвращаемые значения: 

□ ТКУЕ — если вызов удачен; 

□ РАЬ8Е — если вызов неудачен. 










Приложение 2 



Список переменных, имеющих 
тип ЗАПИСЬ или СТРУКТУРА, 
используемых при работе 
с функциями Сгузіаі Нерогі Ргіпі 
Епдіпе АРІ 

Переменная РЕАіегсіпзсапееіпго — содержит информацию о выбранном 
экземпляре Керогс Аіегс. Эта информация используется в функции 

РЕбеСМСЬАІегСІпзСапсеІпіго. 

Суре РЕАІегСІпзСапсеІпСо = гесогд 
ЗСгисСЗіге : ЮогсЦ 
аІегШеззадеЬепдСЬ : НтаІІіпЬ; 


аІегШеззаде : 

епй; 

НИПЙ; 

Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕАІегсіпзСапсеіпСо. Инициализация 
данного параметра осуществляется с помощью константы 

РЕ_ЗІ2ЕОЕ_АЬЕКТ_ІЫЗТШСЕ_ІЫЕО 

аІзегШеззадеЬеп 

дСЪ 

Длина сообщения, создаваемого для данного экземпляра 

КерогС АІегС 

аІегСМеззаде 

Указатель на строку, содержащую сообщение, создаваемое 
для данного экземпляра Керогс Аіегс 


Переменная рЕСіозеВиьсопсііскесіЕѵепсіпго — содержит информацию 
о событии, связанном с нажатием кнопки закрытия окна просмотра 
отчета. При нажатии кнопки закрытия окна просмотра отчета функ¬ 
ция обратной связи будет вызываться с параметром ЕѵепсШ 

РЕ СЬОЗЕ В1ЛТ0Ы СЫСКЕО ЕѴЕЫТ. 
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Приложение 2 


Суре РЕСІозеВиссопСІіскесІЕѵепСІпіо = гѳсогсі 
ЗСгисСЗіге: ѴГогд; 
ѵіеміпйех: Могд; 
міпйомНапсІІ е: НИпд ; 

епсі; 

Компоненты записи Описание компонентов 

ЗСгисСЗіге Размер записи РЕСІозеВиССопСІіскесІЕѵепСіпііо. Инициа¬ 

лизация данного параметра выполняется с помощью констан¬ 
ты РЕ_ЗІ2ЕОР_СЬОЗЕ_ВиТТОЫ_СЬІСКЕО_ЕѴЕЫТ_ІЫЕО 

ѵіеміпсіех Индекс, который указывает на закрываемое окно просмот¬ 

ра. Нумерация начинается с О 

иіпсіоинапсііе Указатель на окно, в котором находится кнопка 

Переменная РЕОгіііопОесаііЕѵепЫп^о — содержит информацию, связан¬ 
ную с данными, возвращаемыми по параметру обратной связи Еѵепс іа = 

РЕ_ОНІЬЬ_ОЫ_ОЕТАХЬ_ЕѴЕЫТ. 

Суре 

РЕРіеІсТ/аІиеІпіоВоиЫеРСг = РЕГіѳІдѴаХиѳХпРоРСг 
РІШгіІІОпОеСаіІЕѵепСІпСо = гесогй 
ЗСгисСЗіге: Иогсі; 
зеІесСесІРіеІсіІпсіех : НшаІІіпС; 
міпйомНапйІе : Ьопдіпъ; 

СіеІсІѴаІиеЬізС : РЕРіе1ЦѴа1иеІпСоЕ>оиЪ1еРСг; 

пРіеІйѴаІие : ЗтаІІіпЪ; 

епй; 

Компоненты записи Описание компонентов 

ЗСгисСЗіге Размер записи рЕОгііЮпОеСаіІЕѵепсіпіо. Инициа¬ 

лизация данного параметра осуществляется с помощью 
константы РЕ_512ЕОЕ_ОКІ ІЩ_Ш_ОЕТАІ Ь_ЕѴЕЫТ_ІЫЕО 

зеІесСесіЕіеІсіІпсіех Индекс, показывающий, какое поле сігііі-сіомп было 

выбрано. Нумерация начинается с 0. Содержит 1, если 
поле не было выбрано 

иіпсіомнапсііе Указатель окна, в котором отработало событие сігііі- 

сіомп 

ііеШѴаІиеЫзС Массив РЕЕіеІсІѴаІие. Память, выделенная под 

йеІсІѴаІиеизІ, освобождается после вызова функции об¬ 
ратной связи 

пЕіеІсіѴаІие Индекс значения в списке йеІсІѴаІиеІізі. Нумерация начи¬ 

нается с 1 
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Переменная РЕВгіііопСгоирЕѵепъіп-ео — определяет информацию о специ¬ 
альной обработке группы по событию ре_шіьь_оы_скоцр_еѵеыт. 
суре 

РЕРСЬагРоіпГег = РСЪаг 
РЕВгіІІОпСгоирЕѵепііпіо = гесогй 
ЗСгисСЗіге: ѴТогд ; 
сігіІІТуре: ѴГогсІ; 
міпйоШапйІ е: НИпд; 
дгоирьізі:: РЕРСЛіагРоіпеег ; 
дгоирЬеѵеІ: ѴГогсІ; 

еп<3; 


Компоненты записи 

Описание компонентов 

ЗігисСЗіге 

Размер записи РЕОгіІЮпСгоирЕѵепііпіо. Инициали¬ 
зация данного параметра производится с помощью кон¬ 
станты РЕ_ЗІ2ЕОГ_ОКІЬЬ_ОЫ_СЕОЦР_ЕѴЕЫТ_ІЫЕО 

сігіІІТуре 

Тип специальной обработки. Используется одно из сле¬ 
дующих значений: 

Константа РЕ_ОЕ_ОГфОР!ОІІР 


Описание компонентов — выделить сумму по группе или 
подгруппе 

Константа РЕ_ОЕ_ОІЧ_еВОІІРТВЕЕ 

Описание — выделить дерево групп 

Константа РЕ_ОЕ_ОЫ_СВАРН 

Описание — выделить графические объекты в группе 
Константа РЕ_ЭЕ_ОЫ_МАР 

Описание — выделить регион на карте 

Константа РЕ_ОЕ_ОЫ_5ШРЕРОРТ 

Описание — выделить подотчет 

міпсІоиНапсІІе 

Указатель окна, в котором произошло событие 

дгоирЬізС 

Список имен групп в отчете и подотчетах. Память, которая 
занимается данным списком, освобождается после вызова 
функции обратной связи 

дгоирЬеѵе! 

Номер группы в списке имен 


Переменная РЕЕпаЫѳЕѵепЫп^о — определяет, какое событие группировки 
является доступным, а какое нет. Все события по умолчанию являются не¬ 
доступными. Для изменения статуса события необходимо использовать 
функцию РЕЕпаЫеЕѵепС. 

Суре РЕЕпаЫеЕѵепСІпіо = гесогй 
ЗСгисСЗіге: Иогй; 
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Приложение 2 


зЬагЬЗЬорЕѵепІ:: ЗшаІІіпЬ; 
геайіпдЕесогсЗЕѵепі; : ЗтаІІіпС; 
ргіпШіпдоадВиССопЕѵепІ:: Зшаіііпе,- 
сісіІІЕѵепС: ЗтаІІіпЬ; 
сІозеРгіпШіпдомЕѵепІ:: ЗтаІІіпЬ ; 
асЬіѵаЬеРгіпШіікіоздЕѵепІ:: Зтаіііпс; 
ііеІсЗМарріпдЕѵепС: ЗтаІІіпЬ; 
тоизеСІіскЕѵепс: ЗтаІІіпЬ; 

ЬурегііпкЕѵепС: Зтаі1іпс; 

ІаипсЬЗеадаЬеАпаІузізЕѵепЬ: ЗтаІІіпС; 

епсЗ; 

Компоненты записи 

Описание компонентов 


ЗЬгисЬЗіге 

Размер записи РЕЕпаЫеЕѵепЫп^о. Инициали¬ 
зация данного значения выполняется с помощью 
КОНСТанТЫ РЕ_ЗІ2ЕОЕ_ЕЫАВЬЕ_ЕѴЕЫТ_ІЫЕО 

зЬагЬЗЬорЕѵепЬ 

Булево значение или РЕ иысшдаЗЕО. 
Старт/Стоп 

Событие 

геасІіпдКесогсІЕѵепІ: 

Булево значение или РЕ_иысНА№ЕО. 
чтения записи 

Событие 

ргіпЬИіпсІонВиСропЕѵепС 

Булево значение или РЕ_иыснА№ЕО. 
нажатия кнопки Печать 

Событие 

ЦгіІІЕѵепЬ 

Булево значение или РЕ__ОМСНАМСЕЕ. 
специальной выборки 

Событие 

сІозеРгіпЬИіпсіомЕѵепЬ 

Булево значение или РЕ_ОЫСНАЫСЕО. 
закрытия окна просмотра отчета 

Событие 

асЬіѵаЬеРгіпЬИіпсІомЕѵепЬ 

Булево значение или РЕ_0ЫСНАЫСЕ0. 
активизации окна просмотра отчета 

Событие 

ііеІОМарріпдЕѵепі; 

Булево значение или РЕ_0ЫСНАЫ6Е0. 
связывания полей 

Событие 

тоизеСІіскЕѵепЬ 

Булево значение или РЕ_ШСНАЫ6Е0. 
нажатия кнопки мыши 

Событие 

Ьурегі іпкЕѵепі: 

Булево значение или РЕ_иыснАЫѲЕО. 
обработки гиперссылки 

Событие 

ІаипсЬЗеадаЬеАпаІузізЕѵепЬ 

Булево значение или ре_тоснаы6Е0. 
СВЯЗКИ С ЗеадаЬе Апаіузіз 

Событие 


( Замечание ) 

Каждый компонент записи может быть определен через значения ТКШЕ, еаьзе 
ИЛИ РЕ ТОСШШЗЕО. 
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Переменная РЕЕхрогРОрРіопз — содержит информацию о формате файла и 
способе обработки, которая получена с помощью функции РЕбесЕхрогсорсіопз. 
Используется в функции РЕЕхрогсто при экспорте отчета. 

Руре 

РЕЛНИатеТуре = аггау[0. . РЕ_ВЬЬ_ЫАМЕ_ЬЕМ-1] ог СЗгаг ; 

РЕЕхроПсОрСіопз = гесогд 
ЗСгисІсЗіге: ИогЗ; 
і. огтаСЦТШате: РЕЮІ ІиатѳТурв ; 

ТогтаСТуре: МогД; 
іогтаШрСіопз : РоіпЪег ; 

ДезСіпаСіопВІ/Шате: РЕОІІИатѳТурѳ ; 
сІезСіпаІсіопТуре: ѴГогсІ; 
сіезСіпаРіопОрСіопз: РоіпРѳг; 
пРогтаСОрСіопзВуСез: ИогЗ; 
гіОезІсіпаСіопОрІсіопзВуСез: ѴГогд.; 

епд; 


Компоненты записи Описание компонентов 

зегисезіге Размер записи РЕЕхрогсоргіопз. Инициализация 

данного значения выполняется с помощью констан¬ 
ты РЕ_5І2Е0Е_ЕХР0КТ_0РТІ0Ы5 

іогтаСОЬШате Строка, содержащая имя библиотеки, длина строки 

РЕ_0И_ЫАМЕ_1.ЕЫ = 64, 

Формат экспорта —СгузТаІ КерогСз ЕогтаТ 
Используемая библиотека — и2ісг.сііі 
Формат экспорта — ВаСа ІпісегсЬапде Еогтас 
Используемая библиотека — сгхф_иогЦи. <111 

іогшаСТуре Тип формата для экспорта отчета Сгузіаі Рерогіз. 

Выбирать можно из представленного списка: 
Формат экспорта — Сгузіаі Рерогіз 

Константа, определяющая тип, — 

иХЕСгузСаІКерогІсТуре 

Формат экспорта — Оаіа ІпІегсНапде 

Константа, определяющая тип, — ихЕОіЕТуре 

Формат экспорта — ѴѴогсІ Іо г ѴѴІпсІоѵѵз 

Константа, определяющая тип, — ихЕНогсШіпТуре 

Формат экспорта — ѴѴогсІ Іог 005 

Константа, определяющая тип, — цхвиогсЮозТуре 

Формат экспорта — ѴѴогсІРегІесІ 

Константа, определяющая тип, — госвиогсІРегіесСТуре 

Формат экспорта — ОиаДго Рго 5.0 (ѴѴВ1) 

Константа, определяющая тип, — ихЕОРЗТуре 
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Приложение 2 


(продолжение) 

Компоненты записи Описание компонентов 

іогтастуре Формат экспорта — ВесогсІ Зіуіе (данные только из 

колонок) 

Константа, определяющая тип, — ихгкесогсіТуре 
Формат экспорта — ВісЬ Тех! Рогтаі 

Константа, определяющая тип, — 

ихГКісЬТехСЕ’огтаСТуре 

Формат экспорта — Сотта Зерагаіесі Ѵаіиез (СЗѴ) 

Константа, определяющая тип, — 

ихГСогтпаЗерагаСесіТуре 

Формат экспорта — ТаЬ Зерагаіесі Ѵаіиез 

Константа, определяющая тип, — 

ЦХРТаЪЗерагаСесІТуре 

Формат экспорта — СЬагасІег Зерагаіесі Ѵаіиез 

Константа, определяющая тип, — 

ЦХЕ’СЬагЗерагаТесіТуре 

Формат экспорта — Техі Рогтаі (АЗСИ) 

Константа, определяющая тип, — цхЕТехСТуре 
Формат экспорта — РадіпаІеЬ Техі (АЗСИ) 

Константа, определяющая тип, — 

ихГРадіпаресІТехСТуре 

Формат экспорта — ТаЬ Зерагаіесі Техі 

Константа, определяющая тип, — 

ЦХРТаЬЬесіТехСТуре 

Формат экспорта — 1_о1из 1 -2-3 (ѴѴКЗ) 

Константа, определяющая тип, — 

ЦХРЬоРизКкЗТуре 

Формат экспорта — Ехсеі 4.0 

Константа, определяющая тип, — охгхіз4Туре 

Формат экспорта — Ехсеі 5.0 

Константа, определяющая тип, — ихгхіз5Туре 

Формат экспорта — Ехсеі 5.0 ТаЬиІаг 

Константа, определяющая тип, — ихгхізТуреТаЬ 

Формат экспорта — СЮВС 

Константа, определяющая тип, — ихгоовстуре 

Формат экспорта — НТМ1_ 

Константа, определяющая тип, — ихгнтмьзтуре 
Формат экспорта — МісгозоИ Іпіегпеі ЕхрІогег2 ИТМЬ 

Константа, определяющая тип, — 

ЦХГЕхр1огег2Туре 

Формат экспорта — №е1зсаре 2 НТМІ 
Константа, определяющая тип, — ихгыеі;зсаре2Туре 
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(продолжение) 

Компоненты записи Описание компонентов 

іогшаЪОрЪіопБ Указатель на тип обработки информации типа дата 

или цифра при экспорте в некоторые виды форматов: 


^Предупреждение^ 


Это значение должно быть определено пе¬ 
ред тем, как будет вызвана функция 
РЕЗіагіРгіпиоЬ. 

Формат экспорта — йаіа ІпІегсЬапде 

Константа, используемая для определения типа, — 

ОХГЦІГОрСіопЗ 

Формат экспорта — Весогб Зіуіе (данные только из 
колонок) 

Константа, используемая для определения типа, — 

ЦХРКесогсіЗСуІеОрЬіопз 

Формат экспорта — Сотта Зерагаіесі Ѵаіиез (СЗѴ) 

Константа, используемая для определения типа, — 

ЦХІГСоттаТаЪЗерагаСесіОрСіопз 

Формат экспорта — ТаЬ Зерагаіесі Ѵаіиез 

Константа, используемая для определения типа, — 

ихРСоштаТаЬЗерагаСесіОрСіопз 

Формат экспорта — СЬагасІег Зерагаіесі Ѵаіиез 

Константа, используемая для определения типа, — 

ЦХВ'СЬагЗерагаресЮрІііопз 

Формат экспорта — Радіпаіесі Техі 

Константа, используемая для определения типа, — 

ЦХГРадіпаРесіТехРОрРіопз 

Формат экспорта — СЮВС 

Константа, используемая для определения типа, — 

ихгсювсорсіопз 

Формат экспорта — НТМІ_ 

Константа, используемая для определения типа, — 

ихгнтмьзорсіопз 

сіезсіпасіопоіщыате Указатель на строку, содержащую имя библиотеки, 

выполняющей требуемую обработку результата 
экспорта (длина строки определяется с помощью 
константы РЕ_ЭИ_^МЕ_1ЕЫ = 64): 

Вид экспорта — Эізк Рііе 

Используемая библиотека — и2сШзк.с111 

Вид экспорта — Е-МаіІ (МАРІ) 
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Приложение 2 
(продолжение) 


Компоненты записи Описание компонентов 

гіезсіпасіопОЬЬЫате Используемая библиотека — и2<±парі . сііі 

Вид экспорта — Е-МаіІ (ѴІМ) 

Используемая библиотека — и2сіѵіт.сі11 
Вид экспорта — МісгозоЬ ЕхсЬапде 
Используемая библиотека — и2фозТ. сііі 

фзСіпаСіопТуре Тип обработки, поддерживаемый выбранной биб¬ 

лиотекой. 

Вид экспорта — Эізк РІІе 

Константа, определяющая тип обработки, — 

иХОЦізкТуре 

Вид экспорта — Е-Ма'іІ (МАРІ) 

Константа, определяющая тип обработки, — 

ЦХОМА РІ Туре 

Вид экспорта — Е-МаіІ (ѴІМ) 

Константа, определяющая тип обработки, — 

ЦХОѴІМТуре 

Вид экспорта — МісгозоЬ ЕхсЬапде 

Константа, определяющая тип обработки, — 

ЦХОЕх сЬ Ро Ісіе гТуре 

сіезсіпаСіопОрсіопз Указатель на запись, содержащую информацию, 

используемую в РЕЕхрогЮрііопз. 


^Предупреждение^ 


Это значение должно быть определено пре¬ 
жде, чем будет вызвана функция 
РЕЗіагіРгіпиоЬ. 

Вид экспорта — Эізк РіІе 

Запись, используемая для определения требуемой 
информации, — ЦХООізкОрСіопз 

Вид экспорта — Е-МаіІ (МАРІ) 

Запись, используемая для определения требуемой 
информации, — ахомдрюрсіопз 

Вид экспорта — Е-МаіІ (ѴІМ) 

Запись, используемая для определения требуемой 
информации, — цхоѵіморсіопз 

Вид экспорта — МісгозоЬ ЕхсЬапде 

Запись, используемая для определения требуемой 

информации, — ІІХОРозСГоІсіегОрСіопз 





Список переменных, имеющих тип ЗАПИСЬ или СТРУКТУРА... 


441 


(окончание) 


Компоненты записи Описание компонентов 


пЕогтасорсіопзВусез Устанавливается с помощью 

РЕСеСЕхрогсОрс і опз и игнорируется 
РЕЕхрогСТо 

пОезсіпаСіопОрсіопзвуСез Устанавливается с помощью 

РЕбеСЕхрогСОрСіопз и игнорируется 
РЕЕхрогСТо 


( Замечание ^ 

Разработчики, использующие ѴізиаІ Вазіс, должны строго следовать требова¬ 
ниям по работе со структурами. 


Переменная РЕРіеіамарріпдЕѵепсіп^о — содержит информацию, связанную 
со стыковкой полей отчета и полей базы данных. 

Суре 

РЕРіеІбМарріпдІпСоРСг = РЕКѳрогЫРіеІіЗМарріпдІпТо ; 

РЕРіеІбМарріпдІпСоОоиЪІеРСг = РЕРіѳІЗМарріпдІпЕоРЪг; 
РЕЕіеІбМарріпдЕѵепСІпСо = гесогй 
ЗЬгисСЗіге : Иогсі; 


герогСЕіеІйз : 
пКерогСРіеІдз : 
йаСаЬазеЕіеШз 
пСаСаЬазеРіеІйз 

еп<5; 

РЕРіеІсЗМарріпдІпЕоВоиЫѳРСг ; 

ИогсЦ 

: РЕРіеІйМарріпдІпіоОоиЫеРСг ; 

: Мог Л; 

Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕРіеІеіМарріпдЕѵепсіпСо. Инициали¬ 
зация данного значения выполняется с помощью констан¬ 
ты РЕ_3I 2ЕОР_РІЕЬОМАРР I ЫѲ_ЕѴЕЫТ_І ЫЕО 

герогСЕіеШз 

Указатель на массив рЕКерогСЕіеІсЗМарріпдіпСо, со¬ 
держащий информацию о полях в отчете 

пКерогСЕіеШз 

Размер массива герогСРіеШз, эквивалентен количест¬ 
ву полей в отчете 

сіаСаЬазеРіеІсІз 

Указатель на массив РЕКерогТГіеІсімарріпдіпСо, со¬ 
держащий информацию о полях в новой базе данных 

пОаТаЬазеРіеІсІз 

Размер массива сЗаСаЬазеПеЫ 
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Переменная РЕ?іеідѴаіиеіп^о — определяет значение поля ііеісіѵаіиеьізс 
В записи РЕОгіІІОгШеСаіІЕѵепСІпбо. 

Суре 

РЕРіеХШатеТуре = ахгау [0.. РЕ_РІЕЬР_ЫАМЕ_ЬШ-1] о€ СЬаг ; 
РЕРіеІйѴаІиеІпіо = гесогй 
ЗСгисСЗіге : ЗДогд; 
ідпогеб : ЭДогй; 

СіеМЦате: РЕГіеІіЭХТатеТуре; 

ХіеІйѴаІие : РЕГѴаІиѳІпіо; 

епсХ; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕРіеІсІѴаІиеіпіо. Инициализация дан¬ 
ного значения выполняется с помощью константы 

РЕ_ЗІ2ЕОГ_ПЕЬО_ѴАШЕ_ІЫГО 

ідпогесі 

Для выравнивания по 4 байта. Игнорируется 

ііеІсіЫате 

Имя поля, длина строки определяется с помощью кон¬ 
станты РЕ_ЕІЕЬО_ИАМЕ_ЬЕЫ = 512 

СіеІсіѴаІие 

Значение поля, указанного в біеісіыате 


Переменная РЕЕопесоіогіпео — содержит информацию, относящуюся 
к заголовку графика. 

Суре 

РЕРасеЫашеТуре = аггау [0. .РЕ_РАСЕ_ХМАМЕ_ЬШ-1] оі СЬаг; 
РЕГопССоіогіпіо = гѳсогд 
ЗСгисСЗіге: Иогд ; 

ХасеЫате: РЕКасеЫатѳТурѳ; 

ХопСРатіІу: ЗтаІІіпС; 

І'опСРіСсЬ: НтаІІіпС ; 
сЬагЗеС : НтаІІіпЬ; 
роіпСЗіге: ЗтаІІіпС; 
ізІСаІіс: атаІІіпЬ; 
ізЦпсХегІіпесХ: ЗтаІІіпС; 
ізЗСгискОиІ;: ЗпіаІІіпС; 
меідЬС: ЗтаІІіпЬ; 
соіог: СОІКЖКЕЕ; 

ШірЗіге: ЗтаІІіпЬ; 

епй; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕЕопССоіогіпХо. Инициализация данно¬ 
го значения выполняется с помощью константы 

РЕ_ЗІ2ЕОГ_ГОЫТ_СОЬОК_ХЫГО 
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(продолжение) 


Компоненты записи Описание компонентов 


СасеЫате 


іопСЕатіІу 


іопСРіСсЪ 


сЬагЗеС 


роіпСЗіге 


ізІСаІіс 


Массив наименований шрифтов, длина наименования оп¬ 
ределяется КОНСТаНТОЙ РЕ_ГАСЕ_ЫАМЕ_ЬЕЫ = 64. 

Пример 

"Тітез Меда Котап” 

Укажите пустую строку если не желаете изменять 
шрифт 

Указатель на семейство шрифтов. Используются следую¬ 
щие константы: 

Константа рр_ооытсаке 

Описание — не требуются изменения 

Константа рр_КОМАЫ 

Описание — шрифт переменной высоты 

Константа РР_зиі55 

Описание — шрифт с постоянной высотой 

Константа РР_МСЮЕКЫ 

Описание — шрифт, имеющий современный стиль 
Константа РР_5СКІРТ 

Описание — шрифт, имеющий рукописный стиль 
Константа рр_оесокатіѵе 
Описание — декоративный шрифт 

Высота шрифта. Используются константы, описанные 
в иіюоиз.н, или константа оераоьт_рітсн для приме¬ 
нения параметра по умолчанию 

Тип кодировки. Используются константы, описанные 

в иіыооиз.н, или константа оераоі,т_снакзет для при¬ 
менения параметра по умолчанию 

Определяет желаемый размер выбранного шрифта. Ис¬ 
пользуется значение из этого поля либо из Смірзіге. Ес¬ 
ли оба элемента ненулевые, тогда данный параметр будет 
проигнорирован и используется СмірЗіге. Установите О 
для ЪиірЗіге и роіпьзіге, если не желаете вносить из¬ 
менения 

Определяет необходимость сделать шрифт наклонным. 
Если равен тлше, то шрифт должен быть наклонным, если 
раьзе — прямым. Использование константы 
РЕ_ШСНАЫѲЕО позволяет применить свойства, опреде¬ 
ленные по умолчанию 
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(окончание) 

Компоненты записи 

Описание компонентов 

ізііпсіегііпесі 


Определяет необходимость сделать шрифт подчеркнутым. 
Если равен ТКЦЕ, то шрифт должен быть с подчеркивани¬ 
ем, если еаьзе — не подчеркнутым. Использование кон¬ 
станты ре_ШСНАЫ6Е0 позволяет применить свойства, оп¬ 
ределенные по умолчанию 

ізЗСгискОиТ: 


Определяет необходимость сделать шрифт перечеркну¬ 
тым. Если равен ТВЛЕ, то шрифт должен быть перечеркну¬ 
тым, если гаьзе — не перечеркнутым. Использование 
константы РЕ ШСНАЫѲЕЭ позволяет применить свойства, 
определенные по умолчанию 

меідЪС 


Вес шрифта. Используется константы, описанные 
в иіыооиз.н. Установите 0, если не требуется вносить 
изменения 

соіог 


Цвета ВОВ, описанные СОЬОККЕЕ, полное описание можно 
найти на Ьйр.Ѵ/тзсіп.тісгозоЙ.согп/. Используйте 

РЕ_ОЫСНА№ЗЕО_СОЬОК для применения параметров по 
умолчанию 

СмірЗіге 


Повторное определение размера шрифта. Используется 
так же, как роіпсзіге. Если оба элемента ненулевые, то 
параметр роіпЕЗіге будет проигнорирован и использует¬ 
ся текущее значение. Установите 0 для смірЗіге и 
роіпсзіге, если не желаете вносить изменения 

Переменная РЕРогтиіаЗупьах — используется в функциях 

РЕбеСЕопшІаЗупСах И РЕЗеСГогтиІаЗупСах ДЛЯ ТОГО, чтобы ПОЛУЧИТЬ ИЛИ 
передать параметры синтаксиса формулы, используемой при вызове через 
функции АРІ. 

Руре РЕРоггоиІаЗупРах = гѳсогй 

ЗРгисРЗіге :Иогй; 

РогтоиІаЗупРах :Зта11іпЬ; 

епд; 

Компоненты записи 

Описание компонентов 

ЗРгисРЗіге 


Размер записи РЕГогтиіаЗуп<:ах. Инициализация данно¬ 
го параметра выполняется с помощью константы 

РЕ_ЗІ2ЕОГ_РОКМЦЬА_ЗУЫТАХ 

іогтиІаЗупСах 


Используйте РЁ_1)ЫСНАЫ0ЕО, если не требуется вносить из¬ 
менения, или константу, определяющую синтаксис формулы: 



Константа ре_езт_скузтаь 
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(окончание) 

Компоненты записи Описание компонентов 

ЕоипиІаЗупсах Описание— значение по умолчанию. Применяется в случае 

использования формулы без изменений 

Константа ре_рзт_ва5іс 

Описание — применяется в случае необходимости переопреде¬ 
ления формулы 

Переменная РЕСепегаіРгіпшіпДоѵЕѵепеіпГо — содержит информацию 
о событиях основного окна просмотра отчета. Эта запись может быть ис¬ 
пользована для обработки множества событий. 

Суре РШепегаІРгіпШіпйоздЕѵепСІпЕо = гесогйі 
ЗСгисСЗіге: Иогд; 
ідпогей: Иогд; 
міпйомНапДІ е: НИпД ; 

епй; 

Компоненты записи Описание компонентов 

ЗСгисСЗіге Размер записи РЕСепегаІРгіпСйіпсіоиЕѵепСІпГо. 

Инициализация данного параметра выполняется с помо¬ 
щью константы РЕ_5I2Е0Е_СЕЫЕКАЬ_РКIЫТ_ИIЫООИ_ 
ЕѴЕЫТ_ІЫРО 

ідпогесі Для выравнивания по 4 байта. Игнорируется 

иіпсіоынапсііе Указатель на окно просмотра отчета, в котором необхо¬ 

димо обработать событие 

Переменная РЕСгарЪАхізіпДо — содержит информацию о сетке, диапазоне 
данных, форматах и параметрах осей указанного графика. 

Суре РЕѲгарЬАхізІпСо = гесогй 
ЗСгисСЗіге : Юогй; 

дгоирАхізСгісІЬіпе : ЗтаІІіпС ; 
сіаСаАхізУСгісІЬіпе : ЗтаІІіпС ; 
сіаСаАхізУ20гісІЬіпе : ЗтаІІіпС; 
зегіезАхізСгіДІіпе : ЗтаІІіпС; 

ДаСаАхізУМіпѴаІие ; ІЭоиЫе; 

СІаСаАхізУМахѴаІие : ОоиЫе; 
йаСаАхізУ2МіпѴа1ие : ОоиЫе; 
йаСаАхізУ2МахѴа1ие : ІЭоиЫе ; 
зегіезАхізМіпѴаІие : ІЭоиЫе; 
зегіезАхізМахѴаІие : ІЭоиЫе; 

ЦаСаАхізУИиіпЬегРогтаС : ЗтаІІіпС; 

ДаСаАхізУ2ЦитЬегРогтаС ; ЗтаІІіпС; 
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зегіезАхізЫшпЪегРогтаІ: : ЭтаІІіпЬ; 
йаЬаАхізУАиЬоКапде : ЗтаІІіпЬ; 
йаЬаАхІБУ2АиЬоКапде : ЭтаІІіпЬ; 
зегіезАхізАиЬоКапде : ЭтаІІіпЬ; 
йаЬаАхізУАиЬотаЬісЕіѵізіоп : ЭтаІІіпЬ; 

даЬаАхізУ2Аи(:ота1:ісВіѵізіоп : ЭтаІІіпЬ; 

зегіезАхізАиЬотаЬісВіѵізіоп : ЭтаІІіпЬ; 

йаЬаАхізУМапиаІВіѵізіоп : ЬопдІпЬ; 
йа(;аАхізУ2Мапиа1Віѵізіоп : ЬопдіпЬ; 
зегіезАхізМапиаІВіѵізіоп ; ЬопдіпЬ; 
йаьаАхізУАиЬоЗсаІе : ЬопдіпЬ; 
йаЬаАхізУ2АиЬоЗса1е : ЬопдіпЬ; 
зегіезАхізАиЬоЗсаІе : ЬопдіпЬ; 

епй; 

Компоненты записи Описание компонентов 

зьгисьзіге Размер записи РЕѲгарЬАхізіпіо. Инициали¬ 
зация данного параметра выполняется с по¬ 
мощью константы 

РЕ_3I2Е0Е_6КАРН_АХI5_ІЫЕО 

дгоирАхізСгісіЫпе Параметры сетки. Используются константы 

РЕ_ССТ_ххх или ре_цыСНАЫСЕ ц, если изме¬ 
нения не требуется 

ЦаЬаАхізУбгісІЫпе Параметры сетки. Используются константы 

РЕ_Ѳ6Т_ХХХ или РЕ_ТОСНАМСЕО, если изме¬ 
нения не требуется 

сіаЬаАхізугѳгісЗЬіпе Параметры сетки. Используются константы 

ре_Сѳт_ххх или ре_шснаысео, если изме¬ 
нения не требуется 

зегіезАхізбгісіііпе Параметры сетки. Используются константы 

ре_ѳѳт_ххх или ре_шснаыѳео, если изме¬ 
нения не требуется 

ЦаьаАхізУМіпѴаІие Минимальное значение для оси 

ЦаЬаАхізУМахѴаІие Максимальное значение для оси 

сіаЬаАхізугміпѴаІие Минимальное значение для оси 

сіаьаАхізугмахѴаІие Максимальное значение для оси 

зегіезАхізМіпѴаІие Минимальное значение для оси 

зегіезАхізМахѴаІие Максимальное значение для оси 

сіаЬаАхізУЫитЬегЕогтаь Формат отображения цифровых значений на 

графике. Используются константы 

ре_ѳые_ххх или ре_ш снАЫбЕЦ, если изме¬ 
нения не требуется 
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(продолжение) 

Компоненты записи Описание компонентов 

гіасаАхізугышпЬегЕ’огтас Формат отображения цифровых значений на 

графике. Используются константы ре_сыг_ххх 
или РЕ_ШСНАЫ6ЕР, если изменения не требу¬ 
ется 

зегіезАхізЫшпЬегЕогтаС Формат отображения цифровых значений на 

графике. Используются константы ре_6ЫГ_ххх 
или ре_шснаысео, если изменения не требу¬ 
ется 

сІасаАхізУАисоКапде Если ТРОЕ, тогда диапазон оси определяется 

автоматически, или ре_шснаысео, если из¬ 
менять параметры не требуется 

сіаСаАхізУгАиСоКапде Если ТРОЕ тогда диапазон оси определяется 

автоматически, или РЕ_ШСНАЫ6Е0, если из¬ 
менять параметры не требуется 

зегіезАхізАиСоРапде Если ТРОЕ тогда диапазон оси определяется 

автоматически или РЕ_ШСНАЫСЕО, если изме¬ 
нять параметры не требуется 

сіаСаАхізУАиСотаСісОіѵізіоп РЕ_А0М__АиТ0МАТ1С, РЕ_АОМ_МАЫЦАЬ ИЛИ 

РЕ_ШСНАЫ6Е0, если изменять параметры не 
требуется 

с!аСаАхізУ2Аи(:отаСіс0іѵІ5іоп. РЕ_АОМ_АОТОМАТІС, РЕ_АОМ_МАШАЦ или 

РЕ_ШСНАШЕО, если изменять параметры не 
требуется 

зегіезАхізАиСотаСісОіѵізіоп РЕ_АОМ_АитОМАТІС, РЕ_АЦМ_МАШАЬ ИЛИ 

ре_шснаы 6Е0, если изменять параметры не 
требуется 

ЦаСаАхізУМапиаЮіѵізіоп Если сіасаАхізУАиСотасісОіѵізіоп равен 

РЕ_АОМ_АитомАТ і с, то данное поле игнори¬ 
руется 

сЗаСаАхізУгмапиаЮіѵізіоп Если сІаСаАхізУгАиСоіпасісОіѵізіоп равен 

ре_а эм_Аитом АТ і с , то данное поле игнори¬ 
руется 

зегіезАхізМапиаЮіѵізіоп Если зегіезАхізАиСошаСісОіѵізіоп равен 

РЕ_АОМ_АатомАТіс, то данное поле игнори¬ 
руется 

ЦасаАхізУАиСоЗсаІе Если ТКЦЕ, тогда ось будет иметь автоматиче¬ 

ски устанавливаемую шкалу, или 
РЕ_ШСНАМ6Е0, если изменять параметры не 
требуется 





448 


Приложение 2 


(окончание) 

Компоненты записи 

Описание компонентов 

с!а(:аАхі5У2Аиі:оЗса1е 

Если ТКЦЕ, тогда ось будет иметь автоматиче¬ 
ски устанавливаемую шкалу, или 

ре_шснаысео, если изменять параметры не 
требуется 

зегіезАхізАиСоЗсаІе 

Если ткце, тогда ось будет иметь автоматиче¬ 
ски устанавливаемую шкалу, или 

РЕ_ШСНАЫСЕО, если изменять параметры не 
требуется 

Переменная РЕСгарьорсіопіпДо — содержит информацию о виде графика и 
ИСПОЛЬЗуетсЯ В функциях РЕСеССгарЬОрЬіопІпііо И РЕЗеСбгарЬОрСіопІпіо. 

Суре РЕСгарЬОрСіопІпіо = гесогй 

ЗСгисСЗіге 

МогД ; 

дгарЬСоІоиг 

атаІІіпС; 

зЬомЬедепй 

ЗтаІІіпЬ; 

1едепДРоз і С і оп 

ЗтаІІіпС; 

ріеЗіге 

Зтаіііпр; 

сіеСасЬеДРіеЗІ ісе 

ЗтаІІіпС; 

ЬагЗіге 

Бтаіііпс,- 

ѵегСісаІВагз 

ЗшаІНпС; 

тагкегЗіге 

ЗтаІІіпЬ; 

тагкегЗЬаре 

5та11іпЬ; 

ДаСаРоіпСз 

ЗтаІІіпС; 

даСаѴаІиеЦишЪегЕоппаС : Зтаіііпс; 

ѵіетпдАпдІе 

ЗтаІІіпС; 

ІедеікЗЬауоиС 

ЗтаІІіпС; 

еп<3; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕСгарЬОрсіопзІпЕо. Инициализа¬ 
ция данного параметра выполняется с помощью кон- 


станты РЕ_512ЕОЕ_СКАРН_ОРТ10Ы_IN ГО 

дгарЬСоІоиг 

Используется одна из констант РЕ ѳск_ххх или 

РЕ ЦЫСНАЫСЕЦ, если изменять параметры не требуется 

зЬомЬедеші 

Если ТКЦЕ, то требуется показывать легенду к графику, 
если еаьзе, то легенду необходимо скрыть или 

РЕ ШСНАШЕО, если изменять параметры не требуется 

ІедепсіРозіСіоп 

Используется одна из констант РЕ_СЬР_ххх или 
РЕ_ШСНАШЕО, если изменять параметры не требу¬ 
ется. Влияет только в случае, когда зЪоиЬедепсІ 
равно ткце 
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(окончание) 

Компоненты записи 

Описание компонентов 

ріеЗіге 

Для графиков типа ріе и осюеншт используется 
одна из констант ре_срз ххх или ре_ТОСНАЫСео, 
если изменять параметры не требуется 

сІеСасЪесІРіеЗІісе 

Для графиков типа ріе и ооіібншт используется 
одна из констант ре_сцрз ххх или ре_шснашео, 
если изменять параметры не требуется 

ЬагЗіге 

Для графиков типа вак используется одна из кон¬ 
стант РЕ_ввз_ххх или РЕ ШСНАЫСЕЦ, если изме¬ 
нять параметры не требуется 

ѵегСісаІВагз 

Для графиков типа вак равна ТКЦЕ, если график 
должен иметь вертикальные области; равна еаьзе, 
если вертикальных областей не будет; равна 
РЕ_ШСНАЫѲЕО, если изменять параметры графика 
не требуется 

шагкегЗіге 

Для линейных графиков и графиков типа вак использу¬ 
ется одна из констант ре_6М$_ххх или ре_шснашео, 
если изменять параметры графика не требуется 

тагкегЗЬаре 

Для линейных графиков и типа ВАК используется одна 
из констант РЕ_СМ5Р_ххх или ре_ШСНАЫ6Е0, если 
изменять параметры графика не требуется 

сіаСаРоіпСз 

Используется одна из констант РЕ_ОТР ххх или 
РЕ_шснаыѳео, если изменять параметры графика 
не требуется 

ЦаСаѴаІиеЫитЪегЕогтаС 

Используется одна из констант РЕ_ѲЫЕ_ххх или 
РЕ_цы С нацсе ц , если изменять параметры графика 
не требуется 

ѵіеміпдАпдІе 

Для трехмерных графиков используется одна из 
констант ре_ѳѵа_ххх или ре_шснаыѳео, если из¬ 
менять параметры графика не требуется 

ІедепсШауоиС 

Определяет вид легенды. Используется одна из кон¬ 
стант РЕ_ѲЬЬ_ХХХ 


Переменная РЕСгарЪТуреіп^о — содержит информацию о типе графика. 
Используется В функциях РЕбеСѲгарЬТуреІпго И РЕЗеЪбгарЬТуреІпіо. 

Суре РЕОгарЪТуреІпіо = гесогй 
ЗСгисСЗіге : Иогд; 
дгарЬТуре : Этаіііпр; 
дгарЪЗиЬСуре : Зпаіііпі; 


епй; 
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Компоненты записи 

Описание компонентов 


ЗЬгисЬЗіге 

Размер записи РЕСгарЬТуреіп^о. Инициализация дан¬ 
ного параметра выполняется с помощью константы 

РЕ_5І2ЕОЕ_вКАРН_ТУРЕ_ІЫЕО 

дгарЬТуре 

Используется одна из констант ре_СТ_ххх или 
РЕ_ЦЫснаысе0, если изменять параметры не требуется 

дгарЬЗиЬьуре 

Используется одна из констант ре 63Т ххх или 
РЕ ШСНАЫСЕО, если изменять параметры не требуется 


Переменная реС гоирОр ы оп з — содержит информацию о параметрах группи¬ 
ровки. Эта информация используется в функции РЕСеьвгоирОрьіопз, для того 
чтобы получить текущую информацию, И В функции РЕЗеЬбгоирОрЫопз, что¬ 
бы передать новые параметры. 

Руре 

РЕРіеІсИатеТурё = аггау [ 0. . РЕ_ЕІЕЬВ_ЫАМЕ_ЬШ-1] оі СЬаг; 

РЕСгоирОрЬіопз = гесогй 

ЗЬгисЬЗіге: ИогсЦ- 

сопйіріоп: ЗтаІІіпЬ; 

ііе1<ЖГате: РИРіѳІсМатеТурѳ ; 

зогРЦігессіоп: ЗтаІІіпЬ; 

гереаЬОгоирНеасІег: ЗтаІІіпЬ; 

кеердгоирТодеЬЪег: ЗтаІІіпЬ; 

ЬорОгВоЬЬотЫОгоирз: ЗтаІІіпЬ; 

ГорОгВоЩоіШЗогГЕіеІДЦате : РЕРі е 1 сІШтеТуре ; 
пТорОгВоГГотСгоирз; ЗтаІІіпЬ; 

6 із сагсЮ ГЪегОг оирз : ЗтаІІіпЬ 
ЬіегагсЫсаІЗогЬіпд: Іпьѳдѳг 
іпзГапсеЮРіеІсЗ: ЗЬгіпд 
рагепЬЮТіеІсЗ: ЗЬгіпд 
дгоирІпйепЬ: ЬопдіпЬ 

епй; 


Компоненты записи 

Описание компонентов 

ЗЬгисЬЗіге 

Размер записи РЕѲгоирОрьіопз. Инициализация 
данного параметра выполняется с помощью констан¬ 
ты РЕ_ЗІ2Е0Е_ѲК0ЦР_0РТІ0ЫЗ 

СопсІіЬіоп 

Условия для выбранной секции группировки. Когда 
необходимо получить информацию о параметрах, 
используются константы РЕ_6С_ТУРЕМАЗК и 

ре_ѲС_сошітіошазк. Когда требуется передать 
параметры группировки, используется одна из кон¬ 
стант РЕ ѲС_ХХХ, И используется РЕ_ШСНАЫСЕО, 
если не требуется вносить изменения в условия груп¬ 
пировки отчета 
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(продолжение) 

Компоненты записи Описание компонентов 

Имя поля базы данных, которое используется в 
качестве условия группирования отчета, длина 
строки определяется константой 

РЕ_ГІЕЬО_ЫАМЕ_ЬЕЫ = 512 

зогСОігесСіоп Константа, указывающая на порядок сортировки, 

описанная ранее, или ре_шснаЫ6Е0, если не 
требуется вносить изменений 

гереасСгоирНеасіег ТКІІЕ, РАЬЗЕ ИЛИ РЕ_таСНАЫ6Е0, если не тре¬ 

буется вносить изменений 

кеербоирТодеСЬег ТІШЕ, РАЬЗЕ ИЛИ РЕ_ШСНАЫ6Е0, если не тре¬ 

буется вносить изменений 

СорОгВоССотЫбгоирз Используется одна из представленных ниже кон¬ 

стант РЕ_ео_твы_ххх или ре_шснаысео, если 
не требуется вносить изменений: 

Константа РЕ_СО_ТВЫ_АЬЬ_6КОиР5_Ш5СЖТЕО 

Описание — нет сортировки по группе или 
Тор/ВоНот N сортировки для данного уровня 
группировки 

Константа ре_со_твы_аь ь_бкоц рз_зоктео 

Описание — данная константа отвечает за груп¬ 
пировку и сортировку Тор/Войот N 

Константа РЕ_С0_ТВЫ_Т0Р_Ы_СК.00РЗ 

Описание — выбрана группа с сортировкой Тор N 
Константа РЕ_ѳо_твы_воттом_ы_ѳкоирз 

Описание — выбрана группа с сортировкой 
ВоНот N 

СорОгВоССотЫЗогСЕіеІсіЫате Имя поля, которое используется для группировки 

и специальной сортировки. Длина имени опреде¬ 
ляется константой РЕ_РІЕІЩ_ЫАМЕ_ЬЕЫ = 512. 
Можно использовать синтаксическую конструкцию 
формулы для изменения данного параметра 

пТорОгВосСотСгоирз Количество групп, которое должно быть выведе¬ 

но по условию Тор І\І/ ВоКот N. Используйте О 
для того, чтобы выполнить сортировку данных по 
группам без дополнительных условий, и 
РЕ_ЦЫснаысе ц, если требуется оставить отчет 
без изменений 

Указатель на необходимость скрытия данных, 
которые попадают в раздел ОіЬегз, или 
РЕ_ШСНАЫ6Е0, если требуется использовать 
настройки отчета по умолчанию 


Еіеісіпате 


сіізсагсЮСЬегбгоирз 
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(окончание) 

Компоненты записи 

Описание компонентов 

ЪіегагсЪісаІЗогСіпд 

Указывает на необходимость иерархической сор¬ 
тировки отчета или ре шснаыѳец в случае не¬ 
обходимости использования параметров, задан¬ 
ных заранее 

іпзСапсеЮЕіеІсІ 

Указатель на экземпляр поля, используемый для 
иерархической группировки и сортировки. Длина 
идентификатора определяется константой 

РЕ_РІЕЬО_НАМЕ_ЬЕЫ = 512 

рагепСІОЕіеІсІ 

Указатель на поле, которое используется в каче¬ 
стве родителя при иерархической группировке и 
сортировке. Длина имени определяется констан¬ 
той РЕ_ЕІЕЬО_ЫАМЕ_ЬЕЫ = 512 

дгоиріпсіепс 

Повторный идентификатор, указывающий на 
иерархическую группировку и сортировку 


Переменная РЕСгоиртгееВиссопсііскеаЕѵепсіпго — представляет инфор¬ 
мацию о событии нажатия кнопки Показать дерево групп (Сгоир Тгее), по¬ 
лученное при обработке функции обратной связи, которая вызывается по 
событию с идентификатором ре_скоцр_ткее_вцттоы_сыскео_еѵеыт. 


Суре РЕОгоирТгееВиССопСІіскесЗЕѵепСІпЕо = гѳсогй 

ЗСгисСЗіге: Иогй; 
ѵізіЫе: ЗтаІІіпС; 
мі пскзиНапсІІ е : Н№кі ; 

епй; 

Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕѲгоирТгееВиССопСІіскесІЕѵепСІпСо. 

Инициализация данного параметра выполняется с помо¬ 
щью КОНСТаНТЫ РЕ 5І2Е0Е ѲКОЦР ТКЕЕ ВЦТТОЫ 

СЫ СКЕЦ_ЕѴЕЫТ_ІЫЕО 

ѵізіЫе 

Показывает, когда дерево групп скрыто, а когда видно 

міпсіомнапсііе 

Указатель на окно просмотра отчета, в котором про¬ 
изошло событие 


Переменная редоЫп^о — содержит информацию о процессе обработки от¬ 
чета, находящемся в активном состоянии. Эта информация используется 
В функции РЕѲеСДоЬЗСаСиз. 

Суре РЕДоМпСо = гесогй 
ЗСгисСЗіге: Иогй; 
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ЦитКесогсізЗеІесСей : 
ЦшіКесогдз Рг іпСеД ; 
ЦізрІауРадеЫ: ИогЦ; 
ЬаСезСРадеЫ: Мог<3; 
ЗсагСРадеЫ: Когсі; 
РгіпСЕпйеД : Вооі; 

епД; 

: Ьопдіпе ; 

Ьопдіпе; 

Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕДоЫпіо. Инициализация данного па¬ 
раметра выполняется с помощью константы 

РЕ 5І2ЕОЕ ЛОВ ІИЕО 

МитКесогЦзКеас! 

Номер записи, которая в данный момент находится в 
режиме чтения 

МитКесогсІзЗеІесТесІ 

Номер записи, выбранной для включения в отчет из все¬ 
го множества записей, считанных из источника 

NитК.есо^с15Р^іпСес1 

Количество записей, реально распечатанных или пока¬ 
занных 

^ізр1ауРадеN 

Номер страницы, показанной на текущий момент в окне 
просмотра отчета 

ЬаСезСРадеН 

Показывает номер страницы, которая была сформирова¬ 
на в момент просмотра, В случае завершения печати 
этот номер будет совпадать с номером последней стра¬ 
ницы отчета 

5ТагГ;РадеМ 

Номер начальной страницы отчета. В нормальной ситуа¬ 
ции номер должен быть равен 1, но можно определить 
другое значение с помощью функции 

РЕЗеСРгіпСОрЪіопз 

ргіпТЕпсІесІ 

Показывает завершение процесса печати. 

• тгше показывает, что процесс завершен. 

• еаьзе показывает, что процесс не закончился. 

Если “печать" подразумевает вывод отчета для просмот¬ 
ра, то Тгие будет получено только тогда, когда будет 
прочитана последняя страница 


Переменная рЕЬодОпіп^о — содержит информацию, используемую для под¬ 
ключения к источнику данных и построению отчета. Эта информация ис¬ 
пользуется В функциях РЕСеШ^ЬТаЫеЬодОпІпіо, РЕЗеШСЪТаЬІеЬодОпІпіо, 
РЕЬодОпЗегѵег И РЕЬодОііЗегѵег ДЛЯ ПОДКЛЮЧеНИЯ И ОТКЛЮЧеНИЯ ОТ ИС¬ 
ТОЧНИКОВ данных. 

’Ьуре 

РЕЬодопЗегѵегТуре = аггау [0 . . РЕ_ЗЕКѴЕКМАМЕ_ЬЕЦ-1] оі. СЬаг; 
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РЕЬодопОВТуре = аггау[0 . .РЕ_ВАТАВАЗ№АМЕ_ЬШ-1] оі СЬаг; 
РЕЬодопІІзегТуре = аггау[0 . . РЕ_Ц5ЕК1Р_1/№-1] оі СЗгаг; 
РЕЬодопРаззТуре = аггау[0 ..РЕ_РАЗЗИ0МЭ_ЬЕЫ-1] оі СЗіаг; 
РЕЬодСпІпіо = гѳоогд 
ЗТгисТЗіге : Иогд; 

ЗегѵегЫате : РЕЬодопЗегѵегТуре; 

ЦаСаЬазеЫате: РЕЬодопБЪТуре; 
из егИ : РЕЬодопІІзегТуре ; 

Раз зѵгогсі : РЕЬодопРаззТуре; 

епй; 


Компоненты записи 

Описание компонентов 

ЗТгискЗіге 

Размер записи РЕЬодОпіп^о. Инициализация производит¬ 
ся С ПОМОЩЬЮ константы РЕ_5І2Е0Е_Ь0ССад INЕО 

ЗегѵегЦате 

Строка, содержащая имя сервера базы данных, длина 
строки определяется константой РЕ ЗЕР.ѴЕР.МАМЕ ьек = 128 

ОаТаЪазеЦате 

Строка, содержащая имя базы данных, длина строки опре¬ 
деляется КОНСТаНТОЙ РЕ_ОАТАВАЗЕЫАМЕ_ЬЕи = 128 

ЦзегЮ 

Имя пользователя базы данных, длина строки определяет¬ 
ся константой РЕ_ЦЗЕКЮ_ЬЕЦ = 128 

Раззмогсі 

Пароль пользователя, длина строки определяется констан¬ 
той РЕ_РАЗЗИОКО_ЬЕМ = 128 


Переменная рЕМоизесііекЕѵѳпеіп^о — содержит информацию, связанную 
с событием нажатия кнопки мыши. Обрабатывается при вызове функции 

обратной связи, когда идентификатор события Ш равен 

РЕ_КІСНТ/МЮОЬЕ/ЬЕЕТ_СЫСК_ЕѴЕЦТ. 

Туре РЕМоизеСІіскЕѵепЫпііо = гесогй 
ЗкгискЗіге : Иогсі; 
ѵіпскжНапсІІе : Ьопдіпк ; 
сІіскАскіоп : ІпЪедег; 
сІіскРІадз : ХпЬедег; 
хОіізеЬ : Іпкедег; 

уОЕЕзеЬ : ІпЪедег,- 

^іеЫѵаІие : РЕѴаІиеІпСо; 
окдесШапсІІе : ПМогЦ ; 
зескіопСойе : ЗшаШпС; 

епй; 


Компоненты записи 

Описание компонентов 

ЗТгисТЗіге 

Размер записи РЕМоизеСІіскЕѵепЫпііо, Инициализиру¬ 
ется С ПОМОЩЬЮ КОНСТаНТЫ РЕ 5І2Е0Е моцзе_сыск_ 
ЕѴЕЦТ_ІЫЕО 
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(продолжение) 

Компоненты записи Описание компонентов 



міпсІомНапсІІе 


Указатель на окно просмотра отчета, в котором произошло 
событие нажатия кнопки мыши 


сііскдссіоп Индикатор действия. Используется одна из представлен¬ 

ных ниже констант ре_моцзе_ххх: 

Константа РЕ_моиЗЕ_штзиРР(ЖТЕО 

Описание — события, связанные с мышью, не поддержи¬ 
ваются 

Константа ре_моцзе_ооим 

Описание — кнопка мыши нажата 
Константа ре_мотг5Е_от 
Описание — кнопка мыши отпущена 
Константа РЕ_МОи5Е_ООЦВЬЕ_СЫСК 

Описание — только в случае двойного щелчка на левой 
кнопке мыши или на центральной кнопке для трехкнопоч¬ 
ной мыши 

сІіскЕІадз Указывает на источник события. Возможны комбинации из 

констант, представленных ниже: 

Константа РЕ_СР_ЫОЫЕ 
Значение — 0x0000 
Описание — кнопки не нажаты 
Константа РЕ_СР_І_ВІІТТОЫ 
Значение — 0x0001 
Описание — левая кнопка 
Константа РЕ_СР_ПВ1ЛТОЫ 
Значение — 0x0002 
Описание — правая кнопка 
Константа РЕ_СР_5НІРТКЕУ 
Значение — 0x0004 

Описание — колесо мыши, если имеется 
Константа РЕ_СР_СОМТПО!_КЕУ 
Значение — 0x0008 

Описание — контрольная кнопка, если имеется 
Константа РЕ_СР_МВ1ЛТОЫ 
Значение — 0x00010 

Описание — Центральная кнопка, если имеется 

ХоЕЕзек Координаты курсора мыши по оси X в момент нажатия 

кнопки, в пикселах 
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(окончание) 

Компоненты записи 

Описание компонентов 

Уоккзек 

Координаты курсора мыши по оси У в момент нажатия 
кнопки, в пикселах 

кіеідѵаіие 

Запись РЕѴаіиеіпко, содержащая информацию о значе¬ 
ниях, определенных для объекта, на котором щелкнули 
курсором мыши, исключая поля типа мемо и вьов, в про¬ 
тивном случае элемент ѵаіиетуре = ре ѵі цоѵаше 

оЬ^ескНапсНе 

Указатель на обрабатываемый объект 

зескіопСосІе 

Код секции, в которой находится обрабатываемый объект 


Переменная РЕрагатекегРіеідіпго — содержит информацию, связан¬ 
ную с полем параметром в отчете. Используется в функции 
РЕСеШкЪРагаліекегГіеІсі ДЛЯ того, чтобы получить информацию о поле, И 
в функции РЕЗеъціЛРагатеСеггіеісі для того, чтобы изменить указанное 
поле параметр. 

ЗД>е 

РЕРагатекегРіеІдѴаІиеТуре = аггау[0. .РЕ_РР_ЫАМЕ_ЬШ-1] оі СЬах; 
РЕ_РР_КерогШатеТуре = аггау[0 ..РЕ_РР_КЕР0НТ_ЫАМЕ_ЬЕЦ-1] оі СЬаг; 
РЕРагатекегРіеІдЛатеТуре = аггау [0. .РЕ_РР_НАМЕ_ЬЕЛ-1] оі СЬаг; 
РЕРагатекегРіеІсЗЕдікМазкТуре = аггау [0. . РЕ_РР_ЕОІТМА5К_ЬЕЛ-1] 

оі СЬаг; 

РЕРагатекегРіеІдІпко = гесогд 
зкгискЗіге: Иогд; 

ѴаІиеТуре: Иогд; 

ОекаиІкѴаІиеЗеЬ: Иогд; 

СиггепкѴаІиеЗек: Иогд; 

Цате: РЕРагатеРегРхвІЦЦапѵеТуре ; 

Рготрк: РЕРагаліекегЕіеІдТехЬТуре ; 

ОекаиІкѴаІие: РЕРагатеЬегРіеІйѴаІиеТуре; 

СиггепкѴаІие: РЕРагатеЬегРіеІдѴаІиеТуре; 

Керо г Шате: РЕ_РР_КерогШатеТурѳ ; 
пеедзСигг епкѵаіие: Иогд ; 
ізЬітікед: Иогд; 

МіпЗіге: ІЭоиЫе; 

МахЗіге: ІЭоиЫе ; 

ЕдіШазк: РЕРагатекегРіеІдЕдіШазкТуре; 
ізНіййеп: Иогд; 

епд; 


Компоненты записи 

Описание компонентов 

ЗкгискЗіге 

Размер записи РЕРагашекегЕіеІсііпко. Инициализация 
данного параметра производится с помощью константы 

РЕ 5І2ЕОЕ РАКАМЕТЕЕ_РІЕШ_ШЕО 
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(окончание) 

Компоненты записи Описание компонентов 

ѵаіиеТуре Тип данных, используемый у поля-параметра. В Сгузіаі 

Перогі поддерживаются типы данных, ассоциированные 
с константами ре_рр_ххх 

ОеГаиізѵаіиеЗеЗ Если теле, то требуется установить новое значение; 

если гаьзе, то значение по умолчанию остается неиз¬ 
менным 

СиггепСѴаІиеЗеС Если ТКЧЕ, то новое значение в поле параметр было ус¬ 

тановлено, если гаьзе, то значение не менялось 

мате Имя поля-параметра. Длина имени соответствует кон¬ 

станте РЕ_РЕ_ЫАМЕ_І^ = 256 

Рготрр Текст подсказки для поля параметра. Длина текста 

РЕ_РЕ_РК°МРТ_ЬЕЫ = 256 

РеТаиІСѴаІие Если ОеРаиІРѴаІиеЗеР равно ГАЬЗЕ, то данное значе¬ 

ние не используется. ЬеіаиІРѴаІие может быть по типу 
ЫитЪег, Сиггепсу, ВаЬе, ВаРеТіте, Тіте, Вооіеап 
или ЗРгіпд. Длина определяется константой 

РЕ_РГ_ѴАЫ1Е_ЬЕМ = 256 

СиггепРѴаІие Если СиггепРѴаІиеЗеР равно ГАЬЗЕ, данное значение 

не используется, СиггепрѴаІие может быть по типу 
ЫитЬег, Сиггепсу, БаРе, БаРеТіте, Тіте, Вооіеап 
или ЗРгіпд. Длина определяется константой 

РЕ_РГ_ѴАЫІЕ_ЬЫ\І = 256 

Керог^ате Имя отчета. Длина имени определяется константой 

РЕ_РГ_КЕРОКТ_МАМЕ_ЬЕЫ =128 

пеесізСиггепРѴаІие Возвращает гаьзе, если параметр является связанным, 

не используется или использует текущее значение 

ізЬітіРесі Если ТШЕ, то: 

• для строковых типов указывает на ограничение 
длины; 

• для других типов ограничение диапазона 

Минимальная длина строки или минимальная цифра 

Максимальная длина строки или максимальная цифра 

Маска, длина шаблона определяется константой 

рер_РГ_еоітмазк_ьеы = 256. Поддерживается только 
для строковых параметров 

ТКЛЕ используется только при наличии внутренних пере¬ 
менных 


МіпЗіге 

МахЗіге 

ЕсІіРМазк 

ізнісісіеп 
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Замечание 


Если вы желаете присвоить параметру значение выберите в качестве 

передаваемого значения СГОЛ/М1Л.1.. 


Переменная РЕрагатеСегріскьізсорсіоп — содержит информацию, связан¬ 
ную с методом сортировки по параметру. 


Суре РЕРагатеСегРіскЬізСОрСіоп = гесогсі 


ЗСгисСЗіге 
зЬомОез сОпІу 
зогСМеСЬоб 
зогСВазебОгШезс 

епб; 

Иогд; 

ЗтаІІіпС; 

ЗтаІІіпС; 

ЗтаІІіпС; 

Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕРагашеСегЕіеІсііпСо. Инициализация 
данного параметра осуществляется с помощью константы 

РЕ_ЗІ2ЕОЕ_РІСК_ЫЗТ_ОРТІОЦ 

зЬомОезсОпІу 

ТГШЕ/ЕАЬЗЕ или РЕ_ц к С н АП С Е 0, если все остается без 
изменений 

зогСМеСЬосі 

Одна из констант РЕ_ОК_ххх или РЕ_ИКСНАКСЕО в слу¬ 
чае отсутствия изменений 

зогСВазесЮпОезс 

ТКЦЕ/ЕАЬЗЕ или ре ОМСНАМСЕО, если все остается без 
изменений 


Переменная РЕРагатеСегѴаіиеіпДо — содержит информацию о типе значе¬ 
ния, которое используется в поле параметре. 

Суре РЕРагатеСегѴаІиеІпСо = гесогд 
ЗСгисСЗіге : Иогд; 
ізЫиІІаЫе : ЗтаІІіпС ; 
бізаІІомЕДісіпд : ЗтаІІіпС; 
аІІомМиІСірІеѴаІиез : ЗтаІІіпС; 

ЬазОізсгеСеѴаІиез : ЗтаІІіпС; 
рагСОССгоир : ЗтаІІіпС; 
дгоирЫит : ЗтаІІіпС; 
тиСиаІІуЕхсІизіѵеСгоир : ЗтаІІіпС; 

епД; 


Компоненты записи 

Описание компонентов 


ЗСгисСЗіге 

Размер записи РЕРагатеТегѴаІиеІпТо. 

Установка 


данного параметра осуществляется через 

РЕ 5І2Е0Е РАКАМ Е ТЕ К ѴАШЕ ІЦЕО 

константу 
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(окончание) 

Компоненты записи 

Описание компонентов 

ізЦиІІаЫе 

Разрешено или нет использование в качестве значе- 


ния параметра шьь и равно ткце/еаьзе или 
ре_ццснамсео, если не требуется ничего менять 

сІізаІІоиЕсІіСіпд 

Указатель на возможность редактирования поля- 
параметра. Равно ТШЕ/ЕАЬЗЕ ИЛИ РЕ_ЦМСНАЫСЕО, 
если все остается без изменений 

аІІомМиІСірІеѴаІиез 

Указатель на допустимость наличия множественных 
значений. Равно ткце/еаьзе или ре_щ\існамсео, 
если все остается без изменений 

ЪазОізсгеСеѴаІиез 

Указатель на свойства поля параметра: 

Константа ре_ок_назяацсе 

Описание — допустимо использование только диапа¬ 
зона 

Константа ре_ок_на50і5СКЕТЕ 

Описание— допустимо использование только дис¬ 
кретных значений 

Константа РЕ_ОК_НАЗОІЗСКЕТЕАЫОКАИСЕ 

Описание — допустимо использование любых вариантов 

рагСОігСгоир 

Указатель на то, что параметр является частью усло¬ 
вия группировки. Равно ТКЦЕ/ЕАЬЗЕ или 

РЕ_ЦЦСНАЦСЕО, если изменения не нужны 

дгоирМит 

Номер группы или РЕ_имснАКСЕО, если все опреде¬ 
лено по умолчанию 

тиСиаІІуЕхсІизіѵеСгоир 

Указатель на то, что параметр является условием для 
взаимоисключающих групп. Равно ТІШЕ/еаьзе или 
ре циснаисео, если условие не обязательно 


Переменная РЕРгіпеореіопз — содержит спецификацию печати, которая 
используется в РЕСеСРгіпьорсіопз для получения текущих настроек и 
РЕЗеЬРгіп^Орѣіопз для определения новых. 

Ъуре 

РЕОиСриСЕіІеЫатеТуре = аггау [0.. РЕ_ЕІЬЕ_РАТН_ЬЕЦ-1] оі СЪаг; 
РЕРгіпсОрСіопз = гѳоогй 
ЗСгисСЗіге: Когй; 

ЗЬагЬРадеЫ : Ѵ7огй ; 

ЗСорРадеЦ: Иогй; 
пКерог ЬСоріез: Иогд; 

СоІІаСіоп: Иогд; 

оиСриСЕіІеЫате : РЕОиРриРЕі 1 еЦатеТуре ; 

епй; 


ІбЗак. 1021 
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Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕРгіпСОрсіопз. Определяется через 
константу РЕ 5І2ЕОЕ РКІЦТ ОРТIОNЗ 

зСагСРадеЦ 

Указатель номера первой страницы для печати 

зСорРадеЦ 

Указатель номера последней страницы при печати 

пКерогССоріез 

Количество копий, которое требуется распечатать 

соІІаСіоп 

Индикатор, указывающий на необходимость разбора ко¬ 
пий при печати 


Константа ре_ццсоъьатео 


Описание — печать множества экземпляров без разбора. 
Пример порядка страниц = 1, 1, 1, 2, 2, 2, 3, 3, 3 и т. д. 


Константа ре_соььатец 


Описание — печать множества экземпляров, с разбором на 
папки. Пример порядка страниц = 1, 2, 3,..., 1, 2, 3,... и т. д. 


Константа ре_бееацьтсоіщатіоы 


Описание — печать отчета с теми параметрами, которые 
заданы заранее при формировании отчета 

оиСриІіЕіІеЦате 

Указатель пути и имени файла, если отчет печатается в 
файл. Длина всего пути должна соответствовать значению, 
определенному константой РЕ_ЕІЬЕ_РАТН_ЬЕЦ = 512 

Переменная РЕКеаоііпдКесогоізЕѵепеіпго — содержит информацию о читае¬ 
мой записи. Считывается в тот момент, когда вызывается функция обратной 

связи по событию с 

идентификатором ю = ре_кеаоімс_кесоко5_еѵеі\іт. 

Суре РЕКеайіпдКесогйзЕѵепСІпіго = гѳсогй 

ЗСгисСЗіге: ИогЦ; 
сапсеііей: ЗшаІІіпР; 
гесогдзВ.еасЗ: ЬопдіпР 

гесогйзЗеІесСед 
йопе: Зшаіііпе; 

: ЬопдіпЬ ; 

епй; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕКеасІіпдКесогсІзЕѵепСіпІіо. Опреде¬ 
ляется С ПОМОЩЬЮ константы РЕ ЗІ2ЕОЕ КЕАШЦС 
КЕСОКОЗ_ЕѴЕЦТ_ІИЕО 

сапсеііесі 

Возвращает еаьзе, если чтение записей было отменено 

гесогсізКеасІ 

Количество считанных записей 

гесогсізЗеІесСесІ 

Количество выбранных записей 

Цопе 

Флаг завершения считывания записей 
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Переменная РЕКерогЬЕіеіамарріпдіпго — содержит информацию о взаимо¬ 
связи полей отчета с полями базы данных. 

Суре 

РЕТаЫеАІіазЫатеТуре = аггау [0. .РЕ_ТАВЬЕ_ЫАМЕ_Ь№ —1] оі СЬаг; 
РЕЕаСаЬазеРіеІсЗЦатеТуре = аггау [ 0. . РЕ_ПАТАВАЗЕ_ЕІЕЬР_ЫАМЕ_ЬЕЦ —1] 

оЩ СЬаг; 

РЕКерогСРіеІЛМарріпдІпіо = гесогЛ 
ЗСгисСЗіге : Ѵ?огд; 
ѵаІиеТуре : МогЦ; 

СаЫеАІіазЦате : РЕТаЫѳАІі азЦатеТуре ; 

ЛаСаЬазеЕіеІсйІате : РЕОаЬаЬазеРіѳІДЦатеТуре; 

тарріпдТо : ІпЪедег; 

епй; 


Компоненты записи Описание компонентов 

зегисезіге Размер записи РЕКерогСЕіеІсІМарріпдіпСо. Инициали¬ 

зация выполняется с помощью константы ре_зі2ЕОЕ_ 
КЕРОКТ_ЕІЕЬОМАРРІШ_:ШЕО 

ѵаІиеТуре Индикатор типа поля: 

Константа РЕ_ЕѴТ_ІИТ83ЕІЕЬ0 

Описание — 8-битное целочисленное с символом 

Константа РЕ_ЕѴТ_ІМТ8ЦЕІЕЬ0 

Описание — 8-битное целочисленное без символа 

Константа РЕ_ЕѴТ_ІПТ163ЕІЕІЛЭ 

Описание — 16-битное целочисленное с символом 

Константа ре_рѵт_іі\іті60Еіеьо 

Описание — 16-битное целочисленное без символа 

Константа ре_еѵт_іі\іт325Еіеьо 

Описание — 32-битное целочисленное с символом 

Константа ре_гѵт_іыт32ЦЕіеьо 

Описание — 32-битное целочисленное без символа 

Константа ре_еѵт_кмзмвекеіеію 

Описание — цифровое поле 

Константа ре_еѵт_сцккецсуеіеьо 

Описание — денежная величина 

Константа ре_еѵт_вооьеамеіеьо 

Описание — булева величина 

Константа ре_еѵт_оатееіеьо 

Описание — дата 

Константа ре_рѵт_тімееіеьо 

_ Описание — время _ 
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(окончание) 

Компоненты записи Описание компонентов 

ѵаіиеТуре Константа ре_еѵт_5ткіысеіеіх> 

Описание — строка 

Константа ре_еѵт_ткацзіецтмемоеіеі,о 

Описание — Тгапзіепі Мето 
Константа ре_еѵт_реез і зтеитмемоеі еію 
Описание — Регзізіепі Мето 
Константа ре_рѵт_вьовріеы> 

Описание — ВЮВ 

Константа ре_еѵт_оатетімееіеьо 

Описание — Дата/Время 
Константа ре_еѵт_вітмареіеьо 
Описание — картинка (ВМР) 

Константа ре_еѵт_ісоцеіеі,о 
Описание — иконка 
Константа ре_еѵт_рістіжееіеьо 
Описание — картинка 
Константа РЕ_ЕѴТ_ОІ,ЕЕІЕІ,0 
Описание — ОІ_Е-объект 
Константа ре_еѵт_сеарнеіеьо 
Описание — графический объект 
Константа ре_рѵт_токж)ШЕіеьо 
Описание — неизвестный тип данных 

СаЫеАІіазЫате Имя таблицы в базе данных. Длина имени определяется 

КОНСтаНТОЙ РЕ_ТАВЬЕ_ЫАМЕ_ЬЕЫ = 1 28 

сіаСаЬазеЕіеІсіЫате Имя колонки в таблице. Длина имени определяется кон¬ 
стантой РЕ_ОАТАВАЗЕ_ЕІЕЬО_ЫАМЕ_ЬЕЫ = 128 

шарріпдТо Индекс поля в массиве сІаСаЬазеЕіеІсі, входящем в 

РЕЕіеІйМарріпдЕѵепсіп^о. Если поле не определено, 
то его индекс равен -1 


Переменная РЕКерогЬАіегеіп^о — содержит информацию о КероП Аіегіз. 
Эта информация используется В функции РЕСеСМСЬКерогСАІегС. 

Суре РЕКерогСАІегСІпСо = гесогд 
ЗСгисСЗіге : Иогй; 
патеЬепд ЬЪ. : ЗтаІІіпС; 
пате : НМпд; 
ізЕпаЫей : ЗтаІІіпЬ; 
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аІегССопйіСіопЬепдСЪ : ЗтаІІіпЬ; 
аІегССопдіСіопЕогтиІа : НИікЗ; 
пТгіддегесІІпзСапсез : т/ЯосЛ; 
аІегСМеззадеЬепдЙі : ЗтаІІІпЬ; 
йеСаиІСАІегШеззадеЬепдСЬ : ЗтаІІІпЬ; 
аІегШеззадеРоппиІа : НМпй; 
йеіаиІСАІегШеззаде : НИпд; 

епй; 

Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕКерогСАіегСіпСо. Инициали¬ 
зируется с помощью константы 

РЕ_ЗІ2ЕОЕ_КЕРОКТ_АЬЕКТ_ІЫЕО 

патеІепдСЪ 

Длина имени Пероіі АІегІ 

пате 

Указатель на строку, содержащую имя Пероіі 
АІегІ. Это имя присваивается в момент создания 
Пероіі АІегІ 

ізЕпаЫеЦ 

Определяет доступность Пероіі АІегІ. Установите 
ТШЛЕ для обеспечения доступа или 

РЕ_ЦЫСНАЫСЕО, если не требуется вносить изме¬ 
нений 

аІегССопсІіСіопЬепдСЪ 

Длина условия, определенного для Пероіі АІегІ 

аІегССопсІіСіопЕогтиІа 

Указатель на строку, содержащую формулу 
Пероіі АІегІ 

пТгіддегесЗіпзСапсез 

Количество отработок НероЦ АІегІ 

аІегСМеззадеЬепдСЪ 

Длина сообщения для Пероіі АІегІ 

сіеіаиІСАІегСМеззадеЬепдСЪ Длина сообщения по умолчанию для Пероіі АІегГ 

аІегСМеззадеЕогтиІа 

Указатель на формулу, используемую для созда¬ 
ния сообщения Нерогі АІегІ 

сІеііаиІСАІегСМеззде 

Указатель на сообщение по умолчанию для Пероіі 
АІегІ 


Переменная РЕКерогеореіопз — содержит информацию о параметрах отче¬ 
та. Эта информация используется в функции РЕСескерогсорсіопз для полу¬ 
чения текущих параметров и в РЕЗеъкерогсорсіопз для их изменения. 

Суре РЕКерог ГОрСіопз = гесогй 
ЗСгисСЗіге : Иогй; 
заѵеБаСаИіСЬКерогС : ЗтаІІіпС; 
заѵеЗигггоагіезИіШКерогС : Зтаіііпе,- 
изеІпаехРогЗрееа : ЗтаІІіпЬ; 

СгапзІаСеШЗЗСгіпдз : ЗтаІІіпЬ г 
СгапзіаЬеШЗМешоз : ЗтаІІіпЬ; 
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сопѵег ЬБа ЬеТітеТуре : ЗшаІІіпЬ; 
сопѵегШиІІРіеІйТоБеіГаиІІ: : ЗшаІІіпЬ; 
тогеРгіпЬЕпдіпеЕггогМеззадез : ЗшаІІіпЬ; 
сазеІпзепзіЬіѵеЗОІЛЭаЬа : ЗшаІІіпЬ; 
ѵегіііуОпЕѵегуРгіпЬ : ЗшаІІіпЬ; 
гоотМойе ; ЗшаІІіпЬ; 

ЬазСгоирТгее : ЗшаІІіпЬ; 

допЬСепегаЬеШЬаРогНійсіепОЬз'есЬз : ЗшаІІіпЬ; 
рег^огтСгоиріпдОпЗегѵег : ЗшаІІіпЬ; 
<5оАзупс0иегу : ЗшаІІіпЬ; 
ргошрШойе ; ЗшаІІіпЬ ; 
зеІесЬОізЬіпсЬКесогсіз : ЗшаІІіпЬ; 
аІмаузЗогЬЬосаІІу : ЗшаІІіпЬ; 
ізКеасЮпІу ; ЗшаІІіпЬ; 
сапЗеІесЬОізЬіпсЬКесогсІз : ЗшаІІіпЬ; 

епй; 


Компоненты записи 

Описание компонентов 

зЬгисЬЗІ 2 е 

Размер записи РЕКерогЬОрЫопз. Оп¬ 
ределяется через константу 

РЕ_312Е0Е_КЕ РОКТ_ОРТIОЫЗ 

заѵеОаЬаИіЬЬКерогЬ 

Флаг, определяющий необходимость 
сохранения данных вместе с отчетом или 
РЕ ШСНАЫСЕО, если не требуется вно¬ 
сить изменения 

заѵеЗиштагіезИіЬЬКерогЬ 

Флаг, определяющий необходимость 
сохранения суммируемых данных вместе 
с отчетом или РЕ_ШСНАЫСЕ0, если не 
требуется вносить изменения 

изеІпсІехЕогЗреесІ 

Флаг, определяющий необходимость 
использования индексов на сервере для 
ускорения доступа к данным или 
РЕ ШСНАЫСЕО для использования пара¬ 
метров по умолчанию 

ЬгапзІаЬеООЗЗЬгіпдз 

Флаг, указывающий на необходимость 
преобразования строк в формате РОЗ 
или ре шснаысер, если не требуется 

вносить изменения 

ЬгапзІаЬеООЗМетоз 

Флаг, указывающий на необходимость 
преобразования полей МЕМО в формате 
005 или РЕ_шснА№ЗЕО, если не требу¬ 
ется вносить изменения 
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Компоненты записи 

сопѵегСОаСеТітеТуре 


сопѵегСЫиІІЕіеІсІТоОеіаиІІ: 

тогеРгіпСЕпдіпеЕггогМеззадез 

сазеІпзепзіРіѵеЗОЬОаІіа 

ѵегіііуОпЕѵегуРгіп’Ь 

гоотМосІе 

ЬазСгоирТгее 

сіопРСепегаРеРаРаЕогНісісІепОЬзесРз 

регЕогтСгоиріпдОпЗегѵег 


(продолжение) 

Описание компонентов 

Флаг конвертации полей типа Дата/Время: 
Константа 

РЕ_КРТОРТ_СѴТОАТЕТІМЕТОЗТК 

Значение О 
Константа 

РЕ_КРТОРТ_СѴТОАТЕТІМЕТСШАТЕ 

Значение 1 
Константа 

РЕ_КРТОРТ_КЕЕРОАТЕТІМЕТУРЕ 

Значение 2 

Флаг конвертации значений ши, в значе¬ 
ния по умолчанию или ре_шснаысео, 
если не требуется изменять ранее опре¬ 
деленные параметры 

Флаг показа дополнительных сообщений 
об ошибках или ре_ШСНАЫСЕО, если не 
требуется изменять ранее определенные 
параметры 

Флаг отключения чувствительности к ре¬ 
гистру букв или ре_ШСНА№ЗЕО, если не 
требуется изменять ранее определенные 
параметры 

Флаг проверки отчета при каждой печати 
или ре_ШСНАЫСЕО, если не требуется 
изменять ранее определенные параметры 

Используется одна из констант 
ре_200м_ххх или ре_шснаы6Е0, если 
не требуется изменять ранее определен¬ 
ные параметры 

Флаг показа дерева групп при просмотре 
отчета или ре_ШСНАЫСЕО, если не требу¬ 
ется изменять ранее определенные пара¬ 
метры 

Флаг генерации данных для скрытых объ¬ 
ектов или ре_цыснаысео, если не требу¬ 
ется изменять ранее определенные пара¬ 
метры 

Флаг выполнения группировки на сервере 
или ре_цыснаысео, если не требуется 
изменять ранее определенные параметры 
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Компоненты записи Описание компонентов 

сіоАз упсОиегу Флаг выполнения запросов асинхронно 

или ре_цыснаысео, если не требуется 
изменять ранее определенные параметры 

рготрсмоеЗе Флаг запроса ввода параметров при за¬ 

пуске отчета на обработку или 
РЕ_іШСНАКСЕО, если не требуется изме¬ 
нять ранее определенные параметры: 

Константа ре_крторт_ркомрт_иоые 

Значение О 

Константа ре_крторт_ркомрт_юкмаь 

Значение 1 

Константа ре_крторт_ркомрт_ашауз 

Значение 2 

зеІесСОізСіпсСКесогсІз Флаг выборки данных без учета дублика¬ 

тов или РЕ_ЦЫСНА№ЗЕО, если не требуется 
изменять ранее определенные параметры 

аІмаузЗогСЬосаІІу Флаг, позволяющий выполнять сортировку 

данных локально или РЕ_ШСНАЫ6Е0, ес¬ 
ли не требуется изменять ранее опреде¬ 
ленные параметры 

ізКеасіОпІу Флаг, указывающий на то, что отчет может 

быть использован только для чтения. Дан¬ 
ное свойство только для чтения 


сапЗеІесСОізСіпсСКесогсЗз Указатель того, что данные в отчет могут 

выбираться без дублирования. Данное 
свойство только для чтения 



Каждый элемент записи может быть определен с помощью ТКІІЕ, РАІ.ЗЕ или 
РЕ_1)ЫСНАЫСЕ0 в случае, если не требуется вносить изменений. 


Переменная РЕКерогезшшпагуіпго — содержит суммарную информацию об 
отчете. 

Суре 

РЕАрр 1 і с а С і огШатеТуре = аггау[0 . .РЕ_ЗІ_АРРЫСАТІОЫ_НАМЕ_ЬШ-1] 

оГ СЬаг г 

РЕТіСІеТуре = агхау [0 . . РЕ_5І_ТІТТ,Е оі СЬаг; 
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РЕЗиЪз есСТуре = аггау [0. . РЕ_ЗІ_ЗЦШЕСТ_Ь№-1] оі СЬаг; 
РЕАиСЪогТуре = аггау[0.,РЕ_ЗІ_А0ТН0К_ЬЕЫ-1] оі СЬаг; 
РЕКеушзгДзТуре = аггау[0..РЕ_ЗІ_КЕУдаГШ8_ЬЕІ\Г-1] оі СЬаг; 
РЕСоішіепСзТуре = аггау[0. .РЕ_ЗІ_СОММЕЫТЗ_ЬЕЫ-1] оі: СЬаг; 
РЕКерогСТетрІаСе = аггау[0..РЕ_5І_КЕРОКТ_ТЕМРЬАТЕ_ЬЕЦ-1] оі СЬаг; 
РЕКерогСЗиттагу = гесогй 
ЗСгисСЗіге: ІпЪедег; 

арр 1ісаСі опМате : РЕАррІісаЪіопЫатеТуре; 

СіСІе: РЕТіЬІѳТурв; 
зиЪзесС: РЕЗиЬзѳсЬТурв; 
аиСЬог: РЕАиЕЬогТуре ; 
кеуѵгагйз; РЕКѳуѵгогйзТуре ; 
сошпепСз: РЕКѳрогЪТетрІаке ; 

епй; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи. Инициализируется с помощью константы 

РЕ_5І2ЕОЕ_КЕРОКТ_5ШМАКУ_:ГОЕО 

аррІісаСіопЫаше 

Имя приложения, использующего отчет. Длина имени 
определяется РЕ_АРРЫСАТІ0Ы_ЫАМЕ_ЬЕЫ = 128. Этот 
параметр только для чтения 

СіСІе 

Заголовок отчета. Длина заголовка задается константой 

РЕ_ТІТЬЕ__ЬЕЫ = 128 

зиЬзесс 

Тема отчета. Длина текста задается константой 

РЕ_ЗІ_ЗЦВДЕСТ_ЬЕЫ =128 

аиСЬог 

Автор отчета. Длина текста задается константой 

РЕ_31 _АОТНОК_І. ЕЫ = 1 28 

кеумогсіз 

Ключевые слова, включенные в отчет. Длина текста зада¬ 
ется константой РЕ 31_КЕУКОКОЗ_ІЕЫ = 128 

соттепСз 

Комментарии к отчету. Длина текста задается константой 

РЕ_5І СОММЕЫТЗ ЬЕЫ =512 

герогСТетрІаСе 

Шаблон отчета. Длина текста задается константой 

РЕ_ЗІ_КЕРОКТ_ТЕМРЬАТЕ_ЬЕЫ = 128 

заѵеРгеѵіемРісСиге 

Флаг, указывающий на необходимость сохранения 
"снимка" отчета или ре_шснаысео, если требуется ис¬ 
пользовать ранее заданные параметры 


Переменная РЕЗеагсЬВиЫ:опсііскесіЕѵѳпеіпео — содержит информацию 
о нажатии кнопки поиска в окне просмотра отчета. 

Суре 

РЕЗеагсЬЗСгіпдТуре = аггау [0..РЕ_ЗЕАКСН_ЗТКІЮЗ_ЬШ-1] оі СЬаг; 
РЕЗеагсЬВиССопСІіскесіЕѵепСІпСо = гесогд 
іл'іпйомНапбІе: ЬопдіпС; 
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зеагсЪЗСгіпд: РЕЗеагсЬЗкгіпдТуре; 

ЗСгисСЗіге : Иогд; 

епй; 


Компоненты записи 

Описание компонентов 

иіпсІоиНапсІІе 

Указатель на окно, в котором произошло событие 

зеагсЬЗкгіпд 

Строка поиска. Длина текста задается константой 

РЕ_ЗЕАКСН_ЗТКІЫС_ЬЕЫ = 128 

ЗкгискЗіге 

Размер записи РЕЗеагсЬВиккопСІіскесІЕѵепкІпІіо. 

Инициализируется с помощью константы ре 5і2еое_ 
ЗЕАКСН_ВЦТТОЫ_СЫСКЕО_ЕѴЕЫТ_ІЫЕО 


Переменная РЕЗессіопОръіопз — содержит спецификацию формати¬ 
рования секции или области отчета. Эти данные используются 
В функциях РЕСеСЗессіопЕотаС, РЕСеСАгеаЕогтаС, РЕЗеСЗесСіопЕогтаі: И 
РЕЗеСАгеаЕогтаС. 


куре РЕЗескіопОркіопз - гѳсогй 
ЗкгискЗіге: Иогй; 
ѵізіЫе: НтаІІіпС; 
пеѵРадеВеігоге: ЗтаІІіпС; 
пемРадеАккег: НтаНіпЬ; 
кеерТодекЬег : Нтаіііпк ; 
зирргеззВІапкЗескіоп: Зтаіііпк ; 
гезекРадеШккег : Зтаіііпк; 
ргіпкАкВоккотОкРаде: Зтаіііпк; 
Ьаскдг оипйС оіог: СОДОННЕЕ; 
ипйегІауЗескіоп: Зтаіііпк; 
зЬомАгеа: Зтаіііпк; 
кгееРопоРІасетепк: Зтаіііпк; 

епй; 


Компоненты записи 

Описание компонентов 

ЗкгискЗіге 

Размер записи РЕЗескіопОркіопз. Определяется 
через константу ре зі2еое зестіоы_ортіоыз 

ѵізіЫе 

Флаг, указывающий на видимость/невидимость 
секции 

пеиРадеВекоге 

Флаг, указывающий на необходимость формиро¬ 
вания разрыва страницы перед печатью секции 

пеиРадеАккег 

Флаг, указывающий на необходимость формиро¬ 
вания разрыва страницы после печати секции 
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(окончание) 

Компоненты записи 

Описание компонентов 

кеерТодеСЬег 

Флаг, указывающий на необходимость совместно¬ 
го размещения объектов из одной секции 

зирргеззВІапкЗесСіоп 

Флаг, позволяющий скрыть пустую секцию 

гезеРРадеЫАГГег 

Флаг, обеспечивающий возможность переустанов¬ 
ки номера страницы после формирования секции 

ргіпГАкВоГРотОГРаде 

Флаг, предоставляющий возможность печатать 
информацию только внизу страницы 

ЪаскдгоипсІСоІог 

Цвет НОВ, описанный в соьоккее или 
ре ыо_соьок, если цвет не нужен 

ипсІегІауЗесСіоп 

Индикатор подчеркивания секции 

зЬомАгеа 

Флаг показа или скрытия раздела 

іігееЕогтРІасетепС 

Флаг, используемый только на дизайне. Позволяет 
разместить объект в любом месте секции 

гезегѵеМіпітитРадеЕооСег 

Флаг, позволяющий уменьшить пустое место в 
нижней части страницы. Если равен ТКЦЕ, то сек¬ 
ция в нижней части будет автоматически миними¬ 
зирована; если равен ЕАЬЗЕ (значение по умолча¬ 
нию), то секция будет занимать столько места, 
сколько было зарезервировано в момент разра¬ 
ботки отчета 


Переменная резѳззіопіпДо — содержит информацию о текущей сессии 
МісгозоГі Ассезз. Многие таблицы базы данных Місгозой Ассезз требуют то¬ 
го, чтобы перед использованием данных была открыта сессия. Используется 
В функциях РЕСеГЖіЬТаЫеЗеззіопІпГо и РЕЗеСГіСЬТаЫеЗеззіопІпГо. 

Гуре 

РЕЗезРаззТуре = аггау [1. .РЕ_5Е88_РА53ШКІ)_ЬЕКІ] о і СЬаг; 

РЕЗеззіопІпГо = гесогй 
ЗСгисСЗіге: Иогд; 

ЦзегГО: РЕЗезРаззТуре; 

Раззѵюгй : РЕЗезРаззТуре; 

Зез з і опНапб! е; ПМогсІ ; 

епД; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕЗеззіопіпГо. Инициализация данного 
параметра выполняется с помощью константы 

РЕ ЗІ2ЕОЕ_ЗЕЗЗІОЫ_ІЫЕО 
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Приложение 2 


(окончание) 

Компоненты записи Описание компонентов 

ЦзегЮ Идентификатор пользователя. Длина строки определяет¬ 

ся константой РЕ_5Е55_Ч5ЕКЮ_ЬЕЫ = 128 

Раззиогсі Пароль пользователя. Длина строки определяется кон¬ 

стантой РЕ_5Е55_РА55ИОКр_ЬЕЫ = 128. Пароль недосту¬ 
пен в случае получения информации из отчета 

ЗеззіопНапсІІе Указатель на текущую сессию М3 Ассезз 


Переменная РЕЗЬоиСгоирЕѵепсіпГо — содержит информацию в том случае, 
когда функция обратной связи вызывается по событию с идентификатором 

Ю = РЕ_5Н0И_СК0ЦР_ЕѴЕЫТ. 

Суре 

РЕРСЪагРоіпСег = РСЬаг; 

РЕЗЬоздСгоирЕѵепСІпіо = гесогй 
ЗСгисСЗіге: Иогй; 
дгоирЬеѵеІ : Могй; 
юіпйомНапйІе : Ьопдіпс ; 
дгоирЬІ5С: РЕРСЪагРоіпСег; 

епй; 

Компоненты записи Описание компонентов 

ЗСгиссзіге Размер записи РЕЗЬомСгоирЕѵепсІпСо. Инициализация 

данного параметра выполняется с помощью константы 

РЕ_ЗІ2ЕОЕ_ЗНОИ_СКОЦР_ЕѴЕЫТ_ІЫЕО 

дгоирЬеѵеІ Номер группы в списке условий группировки 

міпсіомнапсііе Указатель на окно просмотра отчета, в котором произош¬ 

ло событие 

дгоирьізс Массив имен групп, по которым выполняется навигация 


Переменная РЕЗъагСЕѵепсіп^о — содержит начальную информацию о собы¬ 
тии в том случае, когда функция обратной связи отработала по идентифика¬ 
тору события Ю = РЕ_5ТАКТ_ЕѴЕЫТ. 

Суре РЕЗСагСЕѵепСІпСо = гесогй 
ЗСгисСЗіге: Иогй; 
сЗезСіпаСіоп : Иогй; 

епй; 
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Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕЗСагсЕѵепСіпСо. Инициализация дан¬ 
ного параметра выполняется с помощью константы 

РЕ_5І2ЕОЕ 5ТАКТ ЕѴЕЫТ ІЫЕО 

ЦезСіпаСіоп 

Назначение процесса: 

Константа ре_то_жжнеке 

Описание — нет назначения 


Константа ре_то_мішэом 


Описание — просмотр отчета 

Константа ре_то_ркіытек 

Описание — печать отчета на принтер 

Константа ре_то_ехрокт 

Описание — экспорт отчета 

Константа ре_рком_оцеку 

Описание — обработка отчета через запрос 


Переменная резсореѵѳпсіп-ео — содержит информацию о завершении со¬ 
бытия в том случае, когда функция обратной связи отработала по иденти¬ 
фикатору события Ю = РЕ_5Т0Р_ЕѴЕЦТ. 

Суре РЕЗСорЕѵепСІпСо = гесогй 
ЗСгисСЗіге: ИогсЦ 
сЗегСіпаСіоп : Мог<3 
ЗоЬЗСаСиз: Мог<3 ■ 

епй; 


Компоненты записи Описание компонентов 

зегисезіге Размер записи РЕЗСорЕѵепСіпСо. Инициализация дан¬ 

ного параметра выполняется с помощью константы 

РЕ_ЗІ2ЕОЕ_ЗТОР_ЕѴЕЫТ_ІЫГО 

Цезсіпасіоп Назначение процесса: 

Константа ре_то_шшеке 

Описание — нет назначения 

Константа ре_то_иішои 

Описание — просмотр отчета 

Константа ре_то_ркютек 

Описание — печать отчета на принтер 

Константа ре_то_ехрокт 

Описание — экспорт отчета 

Константа ре_еком_оцеку 

Описание — обработка отчета через запрос 
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Приложение 2 


(окончание) 

Описание компонентов 

Константа, показывающая текущий статус процесса: 
Константа ре_то_ыошеке 
О писание — нет назначения 
Константа ре_то_між>ои 
О писание — просмотр отчета 
Константа ре_то_ркіытек 
О писание — печать отчета на принтер 
Константа ре_то_ехрокт 
О писание — экспорт отчета 
Константа ре_рком_()ЦЕКУ 
Описание — обработка отчета через запрос 

Переменная РЕЗиЬгѳрогЫп^о — содержит информацию о подотчете. Эта 
запись используется в функции РЕОесзиЬгерогсіпго для сбора информации 
о выбранном подотчете. 

Суре 

РЕЗиЬгерогШатеТуре = агхау [0. . РЕ_5ШКЕРОКТ_ЦАМЕ_ЬЕН-1] оі. СЬаг; 

РЕЗиЬгерогСІпіо = гесогд 

зкгисСЗіге : Иогд; 

паше : РЕЗиЬгерогШатеТуре; 

Ж.іпкз : ЗтаІІіпЪ; 

ІзОпОетапй : ЗтаІІіпЪ; 
ехСетаІ : Вооі; 
геітрогШркіоп : ЗтаІІіпЪ; 

епй; 

Компоненты записи Описание компонентов 

ЗРгисРЗіге Размер записи РЕЗиЬгерогсіп^о. Инициализация дан¬ 

ного параметра выполняется с помощью константы 

РЕ_5І2ЕОЕ_51ШКЕРОКТ_ІЫЕО 

паше Массив, содержащий имена подотчетов. Длина имени 

подотчета определяется константой 

РЕ_ЗЦВКЕРОКТ_ЫАМЕ_ЬЕЫ= 128 

ыьіпкз Номер связи с данными в основном отчете 

ізОпОешапсі ТРОЕ — если подотчет отображается совместно с основ¬ 

ным отчетом, еаьзе — если подотчет отображается по 
требованию 


Компоненты записи 

ІоЬЗСаСиз 
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(окончание) 

Компоненты записи Описание компонентов 

ехсегпаі ТКОЕ — если подотчет импортирован. ЕАЬЗЕ — если 

встроен 

геішрогсорсіоп Определяет параметры обновления данных в подотчете. 

Равен ре_5Кі_оыорешов, когда требуется обновить 
данные, когда открывается главный отчет, или 
РЕ_ЗКІ_ОЫЕШСТІОЫСАЬЬ, т. е. обновить данные только в 
случае вызова через функции АРІ 

Переменная РЕТаЫеОі^егепсеіпго — запись, используемая только для 
чтения. Содержит информацию о таблице базы данных и используется 
В функции РЕСЬескЫСЬТаЫеОіСІГегепсез. 

Суре РЕТаЫеБі^СегепсеІпСо = гесогсі 
ЗСгисСЗіге : Иогд; 

СаЫеБіССегепсее : пмогЦ ; 

гезегѵесй : ПИогд; 

гезегѵей2 : вюогсі; 

епй; 

Компоненты записи Описание компонентов 

ЗСгисСЗіге Размер записи РЕТаЫеЬосаСіоп. Определяется через 

константу РЕ_ЗІ2ЕОЕ_ТАВЬЕ_ОІЕЕЕКЕЫСЕ_ІЫЕО 

СаЫеОіССегепсез Только для чтения. Возвращает комбинацию констант 

ре_тсо_ххх: 

Константа ре_тсо_окау 

Значение — 0x00000000 

Константа ре_тсо_оатавазештеошо 

Значение — 0x00000001 

Константа ре_тсц_5ЕКѴекыотеошо 

Значение — 0x00000002 

Константа ре_тсо_зееѵекыотореыео 

Значение — 0x00000004 

Константа ре_тсо_аыазснаысео 

Значение — 0x00000008 

Константа ре_тсо_іыоехезснаысео 

Значение — 0x00000010 

Константа ре_тсо_оеіѵееснаысео 

Значение — 0x00000020 
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Приложение 2 


(продолжение) 

Компоненты записи Описание компонентов 

саЫеОіііегепсез Константа РЕ_ТСЭ_ОІСТІОЫАКУСНАЫСЕО 

Значение — 0x00000040 

Константа ре_тсо_еіьетуреснаысео 

Значение — 0x00000080 

Константа ре_тсо_кесокоз і 2 еснаысе и 

Значение — 0x00000100 

Константа ре_тсо_ассе55снаысео 

Значение — 0x00000200 

Константа ре_тсо_ракаметекзснаысео 

Значение — 0x00000400 

Константа ре_тсо_ьосатіоыснаысео 

Значение — 0x00000800 

Константа РЕ_ТСО_ОАТАВАЗЕОТНЕК 

Значение — 0x00001000 

Константа РЕ_ТС0_Ы0МЕІЕЬ03СНАЫСЕ0 

Значение — 0x00010000 

Константа ре_тсо_еіееоотнек 

Значение — 0x00020000 

Константа ре_тсо_еіеі^амеснаі\ісео 

Значение — 0x00040000 

Константа ре_тсо_еіеьооезсснаысео 

Значение — 0x00080000 

Константа ре_тсо_гіеьотуреснаысео 

Значение — 0x00100000 

Константа ре_тсо_еіееозі 2 еснаысео 

Значение — 0x00200000 

Константа ре_тсо_ыатіѵееіеьотуреснаысео 

Значение — 0x00400000 

Константа ре_тсо_ыатіѵее , іеьооетзетснаысео 

Значение — 0x00800000 

Константа ре_тсо_ыатіѵееіеьозі 2 еснаысео 

Значение — 0x01000000 

Константа ре_тсо_еіеьооесрьасезснаысео 

Значение — 0x02000000 

гезегѵесіі Зарезервировано. Не используется 

гезегѵесі2 Зарезервировано. Не используется 
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Переменная РЕТаЫеЬосаЫоп — содержит информацию о местоположении 
базы данных И используется В функциях РЕСеОШДіТаЫеЦосаОіоп и 
РЕЗесШіЬТаЫеЬосаСіоп. 

Суре 

РЕТаЫ еЬ ос Туре = аггау [ 0. . РЕ_ТАВЦЕ_Ц0САТ10М_Ь№ - 1] оі СПаг; 
РЕСоппесСВиССегТуре = аггау [0.. РЕ_СО№таЗТІОЦ_ВЦРЕЕК_ЦЕЦ - 1] 

оі СЬаг; 

РЕТаЫеЬосаСіоп = гѳсогб 
ЗСгисСЗіге : №гй; 

ЬосаСіоп : РЕТаЫѳЬосТуре; 

ЗиЬЬосаСіоп : РЕТаЫ еЬосТуре; { Рог М5 Ассезз ТаЫе Ыатез } 

СоппесСВиТТег : РЕСоппесЬВи^іегТуре; 

еп<3; 


Компоненты записи Описание компонентов 


ЗСгисСЗіге 


ЬосаСіоп 


ЗиЬЬосаСіоп 


СоппесСВиССег 


Размер записи РЕТаЫеЬосаСіоп. Размер задается кон¬ 
стантой РЕ_5І2ЕОЕ_ТАВЦЕ_ЦОСАТІОЦ 

Массив с информацией о местоположении баз данных. 
Длина строки массива задается константой 
РЕ_ТАВЬЕ_ЬОСАТІОЦ_ЬЕЦ = 256. Данное значение долж¬ 
но быть отформатировано в соответствии с представлен¬ 
ными примерами, иначе возможны проблемы при работе 
с функциями, использующими данную запись: 

• хВАЗЕ (Маііѵеіу): <сігіѵе>:\<раІЬ>\<РіІе>; 

• хВАЗЕ (ООВС): ссіаіазоигсе пате>; 

• РагаПох (№ІіѵеІу): <с!гіѵе>:\<ра1Ь>\<ДІе>; 

• Рагасіох (ООВС): ссіаіазоигсе пате>; 

• Вігіеѵе (ІМаІіѵеІу): <Цгіѵе>:\<раІІі>\<ПІе>; 

• Вігіеѵе (ООВС): <Па{азоигсе пате>; 

• Огасіе (ІМаІіѵеІу): <е)а1аЬазе>.<1аЫе>; 

• Огасіе (ООВС): <сіа1аЬа5е>.<іаЫе>; 

• 30і_ Зегѵег (ІМабѵеІу): <сіаіаЬа5е>.<оѵѵпег>.<іаЫе>; 

• 30І_ Зегѵег (ООВС): <сіа1аЬа5е>.<оѵѵпег>.<ІаЫе> 

Дополнительные варианты местоположения базы данных. 
Длина строки массива задается константой 

РЕ_ТАВЬЕ_ЬОСАТІОЦ_ЦЕЫ = 256 

Массив буферов, содержащих информацию о подклю¬ 
ченных таблицах. Длина буфера определяется константой 

РЕ СОШЕСТІОЫ ВЦЕЕЕВ. ЦЕЫ = 512 
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Приложение 2 


Переменная ре таЫе Ргіѵасе іп то — содержит информацию об использова¬ 
нии объектов данных, таких как А00, ОАО, ІШО или СОО, определенных 
через Асііѵе Оаіа Огіѵегз (сгбЬ_або.б11, с гсіЬ_сі ао. сі 11, с гОЬоОЬс .011, 
сі(1Ь_с(1о.(і11). 

Суре 

сгВуСеРоіпСег = ВуСе; 

РЕТаЫеРгіѵаСеІпіо = гесогсі 
ЗСгисСЗіге: ИогЦ; 
пВу Сез: ЗтаіІіпС ; 

Сад: ВМогд; 

ЛаСарСг: сгВуСеРоіпСег • 

епй; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕТаЫеРгіѵасеіліо. Определяется с 
помощью константы РЕ_5І2ЕОГ_ТАВЬЕ_РКІѴАТЕ_ІЫЕО 

пВуСез 

Длина строки ЦаСаРСг 

Сад 

На данный момент значение должно быть равно 3 для 
всех вариантов объектов данных 

ЦаСаРСг 

Указатель на различные варианты драйверов. Для ОАО, 
АОО или элементов ѴізиаІ Вазіс ѴѴіій — Яесогсізеі, для 
СОО — Ноѵѵзеі 


Переменная РЕТаЫеТуре — содержит информацию, необходимую для иден¬ 
тификации типа указанной таблицы. Эта информация собирается с помо¬ 
щью функции РЕСеСЫСЬТаЫеТуре. 

Суре 

РЕБІШатеТуре = аггау [ 0. . РЕ_ВЬЬ_ЦАМЕ_ЬЕКГ- 1 ] оТ СЬаг; 

РЕРиІШашеТуре = агхау [ 0. . РЕ_ЕЦЪЬ_ШМЕ_ЬЕЫ- 1 ] оС СЬаг ; 

РЕТаЫеТуре = гесогсі 
ЗСгисСЗіге: Иогд; 

ВЬШате : РЕП1 ШатѳТуре ; 


ОезсгірСіѵеЫате: 
БВТуре : ИОГд; 

епй; 

РЕЕиІ ШашеТуре; 


Компоненты записи 

Описание компонентов 


ЗСгисСЗіге 

Размер записи РЕТаЫеТуре. 

Установка данного пара- 


метра выполняется с 

РЕ_5І2ЕОЕ_ТАВЬЕ_ТУРЕ 

помощью константы 
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(окончание) 

Компоненты записи Описание компонентов 

ОЬШате Имя библиотеки, обеспечивающей связь с базой данных 

для интересующей таблицы. Длина имени определяется 
константой РЕ_ОШ_ЫАМЕ_ЦЕЫ = 64 

Библиотека — сгбЬ_р2ЬЬсІе.сІІІ 
База данных — Вогіапб ОаІаЬазе Епдіпе 
Библиотека — сгбЬ_сіао.сІІІ 
База данных — ОАО (Ассезз) 

Библиотека — сгбЬ_р2ЬЬс1е.сІІІ 
База данных — Рагабох 
Библиотека — сгбЬ_р2ЬхЬзе.сІІІ 
База данных — 6ВА5Е, РохРго, СІіррег 
Библиотека — сгбЬ_р2ЬЫгѵ.гіІІ 
База данных — Вігіеѵе 
Библиотека — сггіЬ_р2зсіЬ2.сЛІ 
База данных — ОВ2/2 
Библиотека — сггіЬ_обЬс.сІІІ 
База данных — ООВС 
Библиотека — сгсІЬ_огасІе.сЛІ 
База данных — Огасіе 
Библиотека — сгбЬ_р2ззуМ О.сІІІ 
База данных — ЗуЬазе 10/11 

ОезсгірСіѵеЫаше Полное описание таблицы. Длина описания определяется 

константой РЕ_ЕЦЬЬ_ЫАМЕ_І,ЕЫ = 256 

ОВТуре Тип базы данных, которая содержит указанную таблицу 

Константа ре_от_зтаіпж№ 

Описание — стандартная база данных (не 5С)1_) 

Константа ре_эт_зоь 
О писание — реляционная база данных 
Константа ре_е>т_50і._зтокео_ркосешке 
О писание — хранимая процедура 


Переменная рктгаскСигзогіпго — содержит информацию о виде курсора, 
отображаемого в окне просмотра отчета. Используется в функциях 

РЕСесТгаскСигзогІпіо и РЕЗеСТгаскСигзогІпіо. 

Суре РЕТгаскСигзогІпСо = гесогД 
ЗСгисСЗіге: Иогсі; 
дгоирАгеаСигзог: БшаІІіпС; 
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дгоирАгеаРіеІсІСигзог : ЗтаІІіпЬ; 
деСаіІАгеаСигзог: ЗтаІІіпЪ; 
деСаіІАгеаРіеІсІСигзог: ЗтаІІіпЬ; 
дгарЬСигзог: ЗтаІІіпЬ; 
дгоирАгеаСигзогНапдІе: ЬопдіпЪ; 
дгоирАгеаРіеІйСигзогНапсіІе: ЬопдіпЪ ; 
йеРаіІАгеаСигзогНапйІе: ЬопдіпЪ; 
де Раі1АгеаРіеІдСигз огНапдІе: ЬопдіпЬ; 
дгарЬСигз огНапб.1 е: ЬопдіпР ; 
опдетапдЗиЬгерогЬСигзог: ЗшаІІіпЬ; 

ЬурегІіпкСигзог: ЗтаІІіпЬ; 

епд; 

Компоненты записи Описание компонентов 

ЗЬгисЬЗіге Размер записи РЕТгаскСигзогІп^о. Установ¬ 

ка данного параметра выполняется с помощью 
константы РЕ_5І2Е0Е’_ТКАСК_СІЖ50К_ІЫЕ’0 

дгоирАгеаСигзог Определяет тип курсора, отображаемый в раз¬ 

деле группировки. Используется одна из кон¬ 
стант РЕ_ТС_ХХХ ИЛИ РЕ_гаСНАМСЕО, если 
необходимо оставить курсор без изменений 

дгоирАгеаЕіеІдСигзог Определяет тип курсора, отображаемый в раз¬ 

деле группировки у различных полей. Исполь¬ 
зуется одна из констант ре_ТС_ххх или 
РЕ_1)МСНАЫѲЕ0, если необходимо оставить 
курсор без изменений 

деРаіІАгеаСигзог Определяет тип курсора, отображаемый в де¬ 

тальном разделе отчета. Используется одна из 
констант РЕ_ТС_ХХХ ИЛИ РЕ_ОЫСНАЖЗЕО, если 
необходимо оставить курсор без изменений 

десаіІАгеаЕіеісІСигзог Определяет тип курсора, отображаемый в де¬ 

тальном разделе отчета у различных полей. 
Используется одна из констант ре_ТС_ххх или 
РЕ_иыснАЫСЕО, если необходимо оставить 
курсор без изменений 

дгарЬСигзог Определяет тип курсора, отображаемый у гра¬ 

фика, находящегося в разделах Пероіі Неасіег 
или Пероіі Рооіег. Используется одна из кон¬ 
стант РЕ_ТС_ХХХ ИЛИ РЕ_иЫСНАЫСЕО, если 
необходимо оставить курсор без изменений 

дгоирАгеаСигзогНапдІе Зарезервировано. Не используется 

дгоирАгеаЕіедІСигзогНапдІе Зарезервировано. Не используется 

деЬаіІАгеаСигзогНапдІе Зарезервировано. Не используется 

десаіІАгеаЕіеІдСигзогНапдІе Зарезервировано. Не используется 
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Компоненты записи Описание компонентов 


дгарЬСигзогНапсіІе Зарезервировано. Не используется 

опсЗетапсіЗиЪгерогССигзог Определяет курсор, отображаемый для подот¬ 

чета, вызываемого по требованию. По умолча¬ 
нию используется РЕ_ТС_МАСМІБ'Ѵ_СЦЯ50Я 

ЬурегІіпкСигзог Определяет тип курсора, отображаемый для 

гиперссылок. По умолчанию используется 

РЕ ТС НАЦЦ СЦЕЗОК 


Переменная РЕѴаіиеіпТо — содержит информацию, используемую в функциях 

РЕСопѵегСРЕІпХоСоѴІпХо, РЕСопѵегСѴІпХоСоРЕТпХо И РЕЗеСЫСІіРагашеСегЕіеІЦ. 
Суре 

РЕѴАЬШІЫРОЗТЕІЫСТУРЕ = аггау [0 .. РЕ_ѴІ_ЗТКІЫ6_ЬЕЦ- 1 ] ЗтаХХіпС; 
РЕѴАШЕІМРОЦАТЕОКТІМЕТУРЕ = аггау [0.. 5] оі НтаІІіпС; 
РЕѴАШЕІКГРОЦАТЕТІМЕТУРЕ = аггау [ 0 , . 2 ] о і. НтаІІіпС ; 

РЕѴаІиеІпСо = гесогсі 
ЗСгисСЗіге: ИогсЦ 
ѵаІиеТуре: ИогЦ ; 
ѵіЫишЬег: гіоиЫѳ ; 
ѵіСиггепсу: Г)оиЫѳ ; 
ѵіВооІеап: Вооі; 

ѵІЗСгіпд: РЕѴАЬОЕЮТОЗТКШОТУРЕ; 
ѵіЦаСе: РЕУАШЕШРООАТЕОКТХМЕТУРЕ ; 

ѴІЦаСеТІте: РЕѴАЬЦЕІІТЕОБАТЕТШЕТТГРЕ ; 

ѵітіте : РЕУАШЕЮТООЛТЕОНТШЕТУРЕ ; 

ѵіСоіог : СОЬОККЕЕ; 

ѵіІпСедег: ЗшаІІіпС; 

ѵіС: СХшх ; 

ідпогей: СЬаг; 

ѵіЬопд : ЬопдіпС; 

еп<5; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕѴаІиеіпХо. Установка данного пара¬ 
метра выполняется с помощью константы 

РЕ 5І2ЕОГ ѴАШЕ ІЫЕО 

ѵаІиеТуре 

Тип данных поля-параметра: 

Тип данных ЫитЬег 

Константа ре ѵі_шмвее 

Тип данных Сиггепсу 


Константа ре ѵі соеееысу 
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Компоненты записи 


ѵаІиеТуре 


ѴіЫишЬег 

ѵіСиггепсу 

ѵіВооІеап 

ѴіЗСгіпд 

ѴіОаСе 

ѵЮаСеТіте 

ѴіТіте 

ѴіСоІог 

ѵіІпЪедег 

ѴіС 

Ідпогесі 

ѴіЬопд 


(окончание) 

Описание компонентов 

Тип данных Вооіеап 
Константа ре_ѵі_вооьеаы 
Тип данных Оаіе 
Константа ре_ѵі_оате 
Тип данных Зігіпд 
Константа ре_ѵі_зткіыс 
Тип данных ОаіеТіте 
Константа ре_ѵі_оатетіме 
Тип данных Тіте 
Константа ре_ѵі_тіме 
Тип данных Іпіедег 
Константа ре_ѵі_іытесек 
Тип данных СОЮНЕР 
Константа ре_ѵі_соьок 
Тип данных СЬаг 
Константа ре_ѵі_СНАК 
Тип данных 1_опд 
Константа ре_ѵі_ьоыс 
Тип данных N 0 Ѵаіие 
Константа ре_ѵі_ыоѵаше 

Содержит значение, если параметр является цифровым 

Содержит значение, если параметр является денежным 

Содержит значение, если параметр является булевым 

Содержит значение, если параметр является строковым 

Содержит значение, если параметр является датой (год, 
месяц, число) 

Содержит значение, если параметр является Да¬ 
той/Временем (год, месяц, число, часы, минуты, секунды) 

Содержит значение, если параметр является временем 
(часы, минуты, секунды) 

Содержит значение, если параметр определяет цвет 
Содержит значение, если параметр является целочисленным 
Содержит значение, если параметр является символьным 
Только для внутреннего использования. Не используется 
Содержит значение, если параметр относится к типу І_опд... 
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Переменная РЕѴегзіопіп^о — содержит информацию о версии отчета. Эта 
информация используется В функции РЕСеСКерогСѴегзіоп. 

Суре РЕѴегзіопІпіо = гесогсі 
ЗСгисСЗіге : Когсі; 
шаз'ог : ИогЦ ; 
шіпог : МогЙ; 
сЬагасСег : РСЗіаг ; 

епй; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗіге 

Размер записи РЕѴегзіопіпСо. Установка данного па¬ 
раметра выполняется с помощью константы 

РЕ_ЗІ2ЕОЕ_ѴЕКЗІОЫ_ІЫЕО 

ша^ог 

Определяет наивысшую версию 

тіпог 

Определяет наименьшую версию 

ІеССег 

Определяет символьную часть низшей версии. Большин¬ 
ство отчетов не имеет символьной составляющей, поэто¬ 
му возвращается значение ОТЬЬ 


Переменная РЕНіпНоиОрсіопз — содержит информацию, связанную с окном 
просмотра. Эта запись используется в функциях РЕОесиіпсіомОрсіопз и 
РЕЗеСИіпсЗоиОрСіопз . 

Суре РШіпйовдОрСіопз = гесогсі 
ЗСгисСЗіге : Иогй; 

ЬазСгоирТгее: ЗшаІІіпС; 
сапОг і 1 ІБоѵт : ЗшаІІіпС ; 

ЬазЦаѵідаСіопСопСгоІз: ЗшаІІіпС; 

ЬазСапсеІВиССоп: ЗшаІІіпС; 

ЬазРгіпСВиССоп: ЗшаІІіпС; 

ЬазЕхрогСВиССоп ; ЗшаІІіпС; 

Ь,аз2оошСопСго1: ЗшаІІіпС; 

ЬазСІозеВиССоп: ЗшаІІіпС; 

ЬазРгодгеззСопСгоІз; ЗшаІІіпС; 

ЬазЗеагсЬВиССоп : ЗшаІІіпС; 

ЬазРгіпСЗеСирВиССоп: ЗшаІІіпС; 

ЬазКеСгезЬВиССоп : ЗшаІІіпС; 
зЬоадТооІЬагТірз: ЗшаІІіпС; 
зЬоадБосишепСТірз: ЗшаІІіпС; 

ЦазЬаипсЦВиССоп ; ЗшаІІіпС; 


епд; 
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Компоненты записи Описание компонентов 

зыиссзіге Размер записи РЕИіпйоиОрЬіопз. Установка данного 

параметра выполняется с помощью константы 

РЕ_512 ЕОЕ_ИІЮОИ_ОРТ IОЫЗ 

ЬазСгоирТгее Определяет необходимость отображения дерева групп 

в окне просмотра (ткііе/еаьзе) 

сапОгіІЮомп Определяет необходимость разрешить выполнение 

специальной выборки данных в окне просмотра 

(ткііе/еаьзе) 

ЬазЫаѵідасіопСопТгоІз Определяет необходимость отображения кнопок нави¬ 
гации в окне просмотра (ткііе/еаьзе) 

ЬазСапсеІВиТСоп Определяет необходимость отображения кнопки отме¬ 

ны в окне просмотра (ткііе/еаьзе) 

ЬазРгіпЬВиЬЬоп Определяет необходимость отображения кнопки печа¬ 

ти в окне просмотра (ткье/еаьзе). По умолчанию это 
значение равно ткііе. 

ЬазЕхрогРВиЬСоп Определяет необходимость отображения кнопки экс¬ 

порта в окне просмотра (ткііе/еаьзе). По умолчанию 
это значение равно ТКЬЕ 

Ьаз2оотСопсго1 Определяет необходимость отображения элементов 

управления размерами в окне просмотра 
(ТКЬЕ/ЕАЬЗЕ). По умолчанию это значение равно ТКЬЕ 

ЬазСІозеВиЬЬоп Определяет необходимость отображения кнопки за¬ 

крытия окна просмотра (ткііе/еаьзе). По умолчанию 
это значение равно еаьзе 

ЬазРгодгеззСопЬгоІз Определяет необходимость отображения процесса 

загрузки данных в окне просмотра (ткье/еаьзе). По 
умолчанию это значение равно ТКОЕ 

ЬазЗеагсЬВиЬЬоп Определяет необходимость отображения кнопки поис¬ 

ка в окне просмотра (ткье/еаьзе). По умолчанию это 
значение равно еаьзе 

ЪазРгіпьЗеЬирВиЬЬоп Определяет необходимость отображения кнопки на¬ 
стройки принтера в окне просмотра (ткііе/еаьзе) 

ЬазКеЬгезЬВиЬЬоп Определяет необходимость отображения кнопки об¬ 

новления данных в окне просмотра (ткье/ еаьзе) 

зЬомТооІЬагТірз Определяет необходимость отображения подсказок у 

кнопок в окне просмотра (ткые/еаьзе). По умолчанию 
это значение равно ткые 

зЬомЬосшпепЬТ ірз Определяет необходимость отображения подсказок 

для элементов отчета в окне просмотра (ткііе/еаьзе). 
По умолчанию это значение равно еаьзе 

ЬазЬаипсЬВиЬЬоп Определяет необходимость отображения кнопки ссыл¬ 

ки на Сгузіаі Апаіузіз в окне просмотра (ткііе/еаьзе) 
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Переменная РЕ 2 оотЪеѵеісьапдіпдЕѵепЫп^о — содержит информацию 
о записях, считанных в момент срабатывания функции обратной связи по 
событию с идентификатором ю = ре_20ом_ьеѵеь_снаысіыс_еѵеыт. 

Суре РЕ2оотЬеѵе1СЬапдіпдЕѵепСІпСо = гесогсі 
ЗСгисСЗіге: Йог Д; 

2 оошЬеѵе 1: ИогД ; 
иіпсІоиНапсІІе: НИікЗ ; 

епД; 


Компоненты записи 

Описание компонентов 

ЗСгисСЗІ 2 е 

Размер записи РЕ2оотЬеѵе1СЬапдіпдЕѵепСіпСо. Уста¬ 
новка данного параметра выполняется с помощью кон¬ 
станты РЕ_ЗІ2Е0Е_200М_ЬЕѴЕЬ_СНАЦСЫС_ЕѴЕЫТ_ІЫЕ0 

гоошЬеѵеІ 

Уровень увеличения отчета в окне просмотра. Должен 
попадать в диапазон от 25 до 400 либо можно воспользо¬ 
ваться константами: 


РЕ_200М_ ЕЦЬЬ_312 Е 


РЕ_200М_ЗІ2Е_ЕІТ_0ЫЕ_ЗЮЕ 


РЕ_200М_ЗІ2Е_ЕІТ_В0ТН_ЗЮЕЗ 

ніпсІонНапсІІе 

Указатель окна, в котором выполняется изменение мас¬ 
штаба отчета 


Переменная гоаюізкОрсіопз — содержит информацию, которая использует¬ 
ся в записи РЕЕпаЫеЕѵепеіпСо при экспорте. 

Суре ІШЮізкОрСіопз = гесогй 
зСгисСЗіге: Иогй; 
ііІеЫате: РСЬаг; 

епй; 


Компоненты записи Описание компонентов 


зСгисезіге Размер записи цхооізкОреіопз. Установка данного па¬ 

раметра выполняется с помощью константы 

ЦХООізкОрСіопзЗіге 

ііІеЫате Строка, которая содержит полное имя файла для сохранения 


Переменная цхомаріорсіопз — содержит информацию об электронной поч¬ 
те, которая используется в записи РЕЕпаЫеЕѵепсіпіо для экспорта с ис¬ 
пользованием МАРІ. 

Суре ЦХЛМАРІОрСіопз = гесогй 
зСгисСЗіге: Иогй; 
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СоЬізС: РСЬаг; 

ссЬізС: РСЬаг; 

зиЬз ес С: РСЬаг ; 

тез заде: РСЬаг ; 

пКесіріапСз: Иогй; 

гесіріепСз: ІрМаріКесірОезс; 

епй; 


Компоненты записи 

Описание компонентов 

зСгисСЗіге 

Размер записи цхомАРЮрСіопз. Установка данного па¬ 
раметра выполняется с помощью константы 

ЦХОМАРІОрРіопзЗіге 

ЬоЬізІ; 

Строка, содержащая список адресатов. Если установлено 
значение для параметра гесіріепСз, то данный пара¬ 
метр игнорируется 

ссЬізІ 

Строка, содержащая список адресатов, которым отправ¬ 
ляется копия. Если установлено значение для параметра 
гесіріепСз, то данный параметр игнорируется 

зиЬзесР 

Заголовок письма 

теззаде 

Текст письма 

пКесіріепСз 

Количество получателей данного сообщения. Необходи¬ 
мо установить 0 в случае когда параметры РоЫзТ и 
ссЫзс заполнены; только для языка С 

гесіріепСз 

Массив, который содержит информацию о получателях 
сообщения. Для получения более полной информации 
необходимо обратиться к МісгозоЙ'з МАРІ сіоситепіаііоп; 
только для языка С 


Переменная шаэзмюрьіопз — содержит информацию об электронной поч¬ 
те, которая используется в записи РЕЕпаЫеЕѵепсіпТо для экспорта с ис¬ 
пользованием МАРІ. 

Суре ГОЮЗМІОрСіопз = гесогй 
зСгисСЗіге: Могй; 

СоЬІзС: РСЬаГ; 
ссЬізС: РСЬаг; 
зиЬзесС: РСЬаг; 
теззаде: РОіаг; 

епб; 


Компоненты записи 

Описание компонентов 


зСгисСЗіге 

Размер записи цхомдріОрсіопз. 

Установка данного па- 


раметра выполняется с 

ЦХОМАРІОрСіопзЗіге 

помощью константы 
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(окончание) 

Компоненты записи 

Описание компонентов 

СоЬізС 

Строка, содержащая список адресатов. Если установле¬ 
но значение для параметра гесіріепСз, то данный па¬ 
раметр игнорируется 

ссЫзС 

Строка, содержащая список адресатов, которым отправ¬ 
ляется копия, Если установлено значение для параметра 
гесіріепез, то данный параметр игнорируется 

зиЬзесС 

Заголовок письма 

тез заде 

Текст письма 


Переменная гоюРозсроіеіегОръіопз — содержит информацию, необходимую 
для экспорта в МісгозоЙ ЕхсЬап§е. Используется в записи РЕЕпаЫеЕѵепсіпТо. 

Суре ЦХЛРозСРоІсіегОрСіопз = гвсогй 
зСгисСЗіге: Иог<3; 
рзгРгоііІе: РСЬаг 
рзгРаззѵгогд: РСЬаг; 
адВезСТуре: Иогй; 
рз ?.Ро Мег Ра СЪ : РСЬаг; 

епд; 


Компоненты записи Описание компонентов 


зСгисСЗіге 

рзгРгоТіІе 

рзгРаззмогсі 

мОезСТуре 


Размер записи цхврозСЕоІеІегОрсіопз. Установка дан¬ 
ного параметра выполняется с помощью константы 

ЦХОРозСЕоІсіегОрСіопзЗіге 

Профиль ЕхсЬапде 
Пароль для ЕхсЬапде 

Тип экспорта отчета: 

Константа ЦХОЕхсЫГоШегТуре 

Значение — О 

Описание — ѵѵОезІТуре Іог МісгозоЙ ЕхсЬапде Тоісіег 
Константа ЦХОРозСОосМеззаде 
Значение — 1009 

Описание — ѵЮезІТуре Іог іоісіег теззадез 
Константа ЦХВРозСРегзопаІКерогС 
Значение — 1010 

Описание — ѵЮезІТуре Іог регзопаі героіі 
Константа ЦХВРозСЕоіаегКерогС 
Значение — 1011 

Описание — иЮезГГуре Іог Іоісіег герогі 
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(окончание) 

Компоненты записи 

Описание компонентов 

рзгЕЫйегРаСД 

Путь к папке ЕхсЬапде, в которую программа поместит 
экспортируемый файл. Параметр рзгЯоІсіегРаРЬ дол¬ 
жен иметь следующий формат: <Меззаде Зіоге 
Ыате>@<РоІсІеГ №те>@<РоИег Ыате> 

Переменная цхрсьагЗерагаееаор-ьіопз — содержит информацию о том, как 
ВЫПОЛНЯТЬ экспорт цифр И дат ИЗ отчета В формат СЬагасіег ЗерагаіеД. 

Руре ЦХКСИагЗерагаРейОрРіопз = гесогй 
зРгисРЗіге: ИогЦ; 
изеКерогШшпЪегРогтаС : Вооі; 
изеКерогРОаРеРогтаР : Вооі; 
зРгіпдОеІітіРег : СИаг; 
ііеІсЮеІітіРег : РСЬаг; 

епй; 

Компоненты записи 

Описание компонентов 

зРгисРЗіге 

Размер записи ОХГСЬагЗерагаРесЮрРіопз. Установ¬ 
ка данного параметра выполняется с помощью кон¬ 
станты ЦХБ'СЬагЗерагаРесЮрРіопзЗіге 

изеЯерогРЫигоЬегРогіпар 

Если равен ТКОЕ, то в момент экспорта будет исполь¬ 
зован тот же формат для цифр, что и в отчете; если 
равен ттѵьзе, то формат цифр будет оптимизирован 
под выбранный формат файла 

изеКерогрОаРеГогтаР 

Если равен ткце, то в момент экспорта будет исполь¬ 
зован тот же формат для дат, что и в отчете; если ра¬ 
вен еаьзе, то формат дат будет оптимизирован под 
выбранный формат файла 

ЗРгіпдОеІітіРег 

Символ, который желательно использовать для разде¬ 
ления цифробуквенных полей. Можно использовать 
любой символ. Символ должен быть обязательно за¬ 
ключен в кавычки 

ііеІсЮеІітііег 

Строка, содержащая набор символов, которая будет 
использована для разделения полей. Количество сим¬ 
волов в строке может достигать 16, но строка обяза¬ 
тельно должна быть заключена в кавычки 


Переменная тосксоятаТаЪЗерагаЪесЮрЪіопв — содержит информацию о том, 
как ВЫПОЛНЯТЬ экспорт цифр И дат ИЗ отчета В форматы Сотта-Зерагаіесі 
ИЛИ ТаЬ-ЗерагаЬеЦ. 
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Суре ЦХРСоішіаТаЬЗерагаСейОрСіопз = гесогй 
зСгисСЗіге : Ѵ?огй; 
изеКерогШитЬегРогліаС : Вооі ; 
изеКерогСВаСеРонпаС : Вооі ; 

епД; 

Компоненты записи 

Описание компонентов 

зСгисСЗіге 

Размер записи ЦХГСоішпаТаЬЗерагаСесІОрСіопз. 

Установка данного параметра выполняется с помощью 
константы ЦХЕСоптіаТаЬЗерагаСесІОрСіопзЗіге 

изеКерогСЫшпЬегЕогшаС 

Если равен ткое, то в момент экспорта будет ис¬ 
пользован тот же формат для цифр, что и в отчете; 
если равен еаьзе, то формат цифр будет оптимизи¬ 
рован под выбранный формат файла 

изеКерогСОаСеЕогшаС 

Если равен ткце, то в момент экспорта будет ис¬ 
пользован тот же формат для дат, что и в отчете; 
если равен еаьзе, то формат дат будет оптимизиро¬ 
ван под выбранный формат файла 

Переменная цхепірорсіопз — содержит информацию о том, как выполнять 
экспорт цифр И дат ИЗ отчета в формат ОІК (ЦаСа ІпСегсЪапде ЕогшаС) . 

Суре ЦХГОІРОрСіопз = гѳсогй 
зСгисСЗіге: ИогД; 
изеКерогСЦишЬегРогшаС : Вооі ; 
изеКерогСОаСеРогшаС : Вооі; 

епй; 

Компоненты записи 

Описание компонентов 

зСгисСЗіге 

Размер записи ихгоіЕОрсіопз. Установка данного 
параметра выполняется с помощью константы 

ЦХЕОІГОрСіопзЗіге 

изеКерогСЫишЬегЕогшаС 

Если равен типе, то в момент экспорта будет ис¬ 
пользован тот же формат для цифр, что и в отчете; 
если равен еаьзе, то формат цифр будет оптимизи¬ 
рован под выбранный формат файла 

изеКерогСОаСеЕогшаС 

Если равен ТШЕ, то в момент экспорта будет ис¬ 
пользован тот же формат для дат, что и в отчете; 
если равен ЕАЬЗЕ, то формат дат будет оптимизиро¬ 
ван под выбранный формат файла 


Переменная цхкнтмьзорсіопз — содержит параметры, используемые в запи¬ 
си РЕЕпаЫеЕѵепъіпіо для экспорта отчета в формат НТМЬ. 
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Суре ЦХРНТМЬЗОрСіопз 
зЬгисЬЗіге : МогД; 
ііІеЫате: РОіаг; 

епсЗ; 

= гесогЦ 

Компоненты записи 

Описание компонентов 

зСгисРЗіге 

Размер записи ихРНТМЬЗОреіопз. Установка данного 
параметра выполняется с помощью константы 

ихГНТМЬЗОре і опзЗ і ге 

ііІеЫате 

Полное имя файла, например, "С: \ри Ь\бос5\ЬохоТСіс\ 
сІеІаиІІМт' . В случае экспорта графических файлов они 
сохраняются в тот же самый каталог 

Переменная цхкоовсореіопз — содержит информацию, необходимую при 
экспорте с использованием СШВС. 

Суре ЦХРОВВСОрЬіопз = гесогй 
зЬгисЬЗіге : Иогй; 

ДаСаЗоигсеИате : РСЬаг; 

ЦайаЗоигсеЦзегЮ: РСЬаг,- 
даСаЗоигсеРаззмогд: РСЬаг,- 
ехрогСТаЫеЦате: РСЬах; 

епй; 

Компоненты записи 

Описание компонентов 

зСгисСЗіге 

Размер записи ихгсювсорсіопз. Установка данного 
параметра выполняется с помощью константы 

иХГСЮВСОрСіопзЗіге 

сІаСаЗоигсеЫате 

Имя ООВС-источника, используемого для экспорта 

сІаСаЗоигсеЦзегЮ 

Имя пользователя, если необходимо 

ЦаСаЗоигсеРаззмогсІ 

Пароль 

ехрогСТаЫеЫате 

Имя таблицы, в которую будут сохранены экспорти¬ 
руемые данные 


Переменная цхкрадіпаеецтѳхеореіопз — содержит информацию, исполь¬ 
зуемую при экспорте в разбитый на страницы текст. 

Суре ЦХРРадіпаеесіТехеОреіопз = гесогй 
зегисеЗіге: Иогй; 
пЬіпез РегРаде: Ѵ/огй ; 

епй; 
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Компоненты записи 

Описание компонентов 

зСгисСЗіге 

Размер записи ОХРРадіпаСесІТехСОрСІопз. Уста¬ 
новка данного параметра выполняется с помощью 
константы ОХРРадіпаСесЗТехСОрСіопзЗіге 

пЬіпезРегРаде 

Количество строк на страницу. По умолчанию коли¬ 
чество строк 60. Когда выполняется экспорт в данный 
формат, пользователю предлагается диалог для вво¬ 
да количества строк на страницу 

Переменная цхЕКесогазьуіеОрьіопз — содержит информацию о том, как 
ВЫПОЛНЯТЬ ЭКСПОРТ цифр И Дат ИЗ отчета В формат КесогЦ зСуІе (соіитпз 
оі ѵаіиез). 

Суре ЦХРКесогсЗЗСуІеОрСіопз = гесогй 
зСгисСЗіге-. ИогЦ; 
изеКерогШитЬегРогтаС : Вооі; 
изеКерогСВаСеРоігпаС : Вооі ; 

епй; 

Компоненты записи 

Описание компонентов 

зСгисСЗіге 

Размер записи ихЕКесогйзсуІеОрСіопз. Установ¬ 
ка данного параметра выполняется с помощью кон¬ 
станты ЦХГКесогсІЗСуІеОрСіопзЗіге 

изеКерогСЫитЬегГотаС 

Если равен твое, то в момент экспорта будет ис¬ 
пользован тот же формат для цифр, что и в отчете; 
если равен гаьзе, то формат цифр будет оптимизи¬ 
рован под выбранный формат файла 

изеКерогЮаСеЕогтаС 

Если равен ТКЦЕ, то в момент экспорта будет ис¬ 
пользован тот же формат для дат, что и в отчете; 
если равен гаьзе, то формат дат будет оптимизиро¬ 
ван под выбранный формат файла 







